Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Testing for notebooks #25

Merged
merged 4 commits into from
May 7, 2024
Merged

Testing for notebooks #25

merged 4 commits into from
May 7, 2024

Conversation

venaturum
Copy link
Member

Setup for tox and github actions.

Currently tests will fail due to errors in notebooks, which will be addressed in separate pull request

@venaturum
Copy link
Member Author

@Marika-K this PR doesn't change any notebooks, it just sets up the framework to test them, so currently tests will not pass.

Further down the line we might want to separate each notebook into it's own test.

@venaturum venaturum mentioned this pull request Apr 29, 2024
@mattmilten mattmilten self-requested a review May 3, 2024 09:29
@mattmilten
Copy link
Member

Looks good - thanks! Is there a reason for defining specific versions for all packages in the requirements file? I would just remove all of those, so we always pick the latest.

@venaturum
Copy link
Member Author

Looks good - thanks! Is there a reason for defining specific versions for all packages in the requirements file? I would just remove all of those, so we always pick the latest.

Yeh it was a very deliberate action. This requirements file is supposed to act as a lockfile. If we were managing this project with Poetry or Pipenv - which would be a good idea considering the amount of easily breakable code - then we would be using a lockfile by default under the hood. This is pretty standard in modern package managers, Python and non-Python.

When someone submits a change to code we really want the tests to test only the code changes. Without a lockfile you are almost certainly testing a change in environment too, and this should be kept separate. We want to avoid the scenario where something runs on one computer, but the same code on another computer does not. The only way around this is a lockfile. You and I could create fresh virtual environments and ask for the latest package versions at the same precise instant and end up with different environments. Maybe mine works with a particular notebook and yours does not.

This is different from mandating that users of these notebooks have to use certain package versions. It will be a case of "use whatever environment you like, it may work, but we only guarantee it works for the environment defined here: ....". We make statements similar to this in the notebooks: "tested with Python 3.12 and gurobipy 11", but this is only a small part of the story.

@mattmilten
Copy link
Member

OK, excellent! Then, we just have to update this requirements file every now and then to get the latest Gurobi version.

@Marika-K Marika-K merged commit 25f7b26 into Gurobi:master May 7, 2024
1 of 3 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants