Skip to content

Latest commit

 

History

History
110 lines (88 loc) · 6.76 KB

CHANGELOG.md

File metadata and controls

110 lines (88 loc) · 6.76 KB

Changelog

All notable changes to the PyPI package for SWE-bench (swebench) will be documented in this file.

Prior to version 1.1.0, not all deployed versions are listed, as the PyPI package was going through development and testing. The noteworthy versions and the respective changes that were introduced by that version are included. All versions 1.1.0 onwards are fully listed.

[2.0.11] - 7/15/2024

  • Minor naming changes
  • #183 Fix timeout
  • #178 Add schema version to report card
  • #177 Fix run live scripts

[2.0.9] - 7/10/2024

  • #176 Move inference to swebench.inference sub-package
  • #175 Fix link in collect README.md

[2.0.8] - 7/8/2024

  • Add cutoff_date, max_pulls arguments to collection pipeline
  • Minor Django issue comment parsing logic
  • Rewritten extract_patches logic
  • Remove MAP_REPO_TO_TEST_FRAMEWORK symbol

[2.0.4] - 7/5/2024

  • #173 Fix: Allow to set GH token from env var in collect/print_pulls
  • #171 Don't let tox install a virtualenv during evaluation
  • #169 Handle failures because of None/empty patches

[2.0.3] - 7/2/2024

  • #149 Interface fix: run_id is required
  • #151 Fix: Support JSON datasets (avoid loading json twice)
  • #152 Add very simple CI
  • #153 Various nitpicks
  • #155 Fix link to collection tutorial
  • #161 Fix path to image in docs
  • #162 Fix evaluation hanging issue and improve patch apply
  • #164 Fix so it doesn't crash when no env imgs to build
  • #166 Fix newline outputs for django's log parser
  • #168 Update reporting and skip empty model patch predictions

[2.0.0] - 6/27/2024

Major release - the SWE-bench evaluation harness has been upgraded to incorporate containerized, sandboxed execution environments based on Docker. There are several chances to the API resulting from this:

  • Removal of the swebench.metrics module
  • Updates to the API of swebench.harness functionality
  • Significant modifications to underlying evaluation logic
  • Minor updates to installation specifications for different repos + versions.

Read the full report here

[1.1.5] - 5/15/2024

  • Add support for HumanEvalFix (Python, JS, Go, Java) (source)

[1.1.0] - 4/15/2024

  • Add env_vars_test field to allow for environment variable assignment for testing scripts.
  • Change pip_packages installation specification to be a list instead of a string.
  • Define PyPI package versioning explicitly for dev, test repos.
  • Fix versioning for astroid dependency in pylint installation script`.
  • Fix minor error in parse_log_pytest_options.
  • Improve clarity + succinctness of logging.
  • Make logging of subprocess args to log file smaller.
  • Remove installation specifications for dbt-core, transformers.
  • Remove redundant declaration of constants.
  • Remove unused versions from installation specifications for dev, test repos.
  • Rewrite swebench.metrics.get_model_report.

[1.0.5] - 4/7/2024

  • Fix log parsing for pydicom, pylint, and requests libraries. 5cb448

[1.0.4] - 4/5/2024

  • Fixed env_list parsing. 5be59d
  • Updated ExecWrapper, LogWrapper logic for harness. 231a2b

[1.0.2] - 4/2/2024

  • Added try/catch around lsof based clean up for run_evaluation.py. 3fb217
  • Fixed get_eval_refs function. 12a287
  • Fixed seaborn log parser. 0372b6

[1.0.1] - 3/31/2024

First working version. We strongly recommend not using versions older than this one.

  • Added logging for failed installations. 58d24d
  • Added missing datasets dependency. 68e89e
  • Reorganized repository to be directly build-able as a PyPI package. 548bdb

[0.6.9 - 0.6.9.2] - 3/31/2024

⚠️ Do NOT use these versions. The PyPI package for these versions was under development. Specifically, some of the evaluation configurations required re-validation. A detailed report for the failures and our recovery from it are detailed in Bug Report 4/5/2024.

[0.6.1] - 3/14/2023

  • Added minor conditions to make run_evaluation more robust (e.g. exit on empty predictions)
  • Added logic that conditions conda link download based on which architecture/platform (e.g. x86, arm) the code is being run on.
  • Added classes to unify subprocess execution arguments + make them more consistent throughout the codebase. Also remove shell=True flag when not necessary.
  • Added deterministic hashing of model name when creating certain testbed paths, defends against conda/conda#12250
  • Fixed key errors across the metrics/ folder.
  • Reorganized harness code. Moved constants into a separate file to improve readability.

[0.4.8] - 11/8/2023

  • run_evaluation can be imported to make running the evaluation harness of SWE-bench more accessible.
  • Add condition in harness/context_manager.py to skip installation if no instructions are provided.
  • Add functionality to check and remove logs with AttributeError or ImportError
  • Add support for HumanEval dataset.
  • Add support for relative paths for log_dir and testbed arguments of evaluation.
  • Minor renaming for metrics/report.py variables.

[0.4.3] - 11/5/2023

Introducing the initial release of SWE-Bench, a novel benchmark that introduces "software engineering as a task". Given a codebase and an issue, a model is tasked with writing a .patch file that addresses the desired changes.

Please view the README.md for information on how to run the repository, and check out our paper, SWE-bench: Can Language Models Resolve Real-World GitHub Issues?, for full details on the project.

We will maintain a leaderboard on the SWE-bench public website. We will release details soon on how to submit your generations for evaluation to be included on the leaderboard.

[< 0.4.3] - 11/4/2023

⚠️ Do NOT use these versions. The PyPI package was under development for these versions and will not work properly.