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

fix ci issue #52

Merged
merged 11 commits into from
May 31, 2024
Merged

fix ci issue #52

merged 11 commits into from
May 31, 2024

Conversation

takojunior
Copy link
Contributor

@takojunior takojunior commented May 7, 2024

Hi @skadio , this PR is to fix the failing CI checks. I see that CI checks failed because python 3.7 is no longer supported in runner image `macos-latest' (that is macos 14) for tests. So I think it could be ok to drop 3.7.

We can add 3.11 instead. Some tests failed in 3.12 though, due to common packages not found in the image. So 3.11 seems far enough for now.

Then I updated installation information in readme and docs, for being consistent to tests. Since these are docs changes, and no library code changes, I think we don't need to update release version or changelog.

@takojunior takojunior requested a review from skadio May 7, 2024 20:36
README.md Outdated
@@ -114,7 +114,7 @@ our [documentation](https://fidelity.github.io/seq2pat/installation.html).

### Requirements

The library requires ```Python 3.7+```, the ```Cython``` package, and a ```C++``` compiler.
The library requires ```Python 3.8+```, the ```Cython``` package, and a ```C++``` compiler.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

add this to changelong and bump up the version. This seems like a major change? so may be jump to 2.0.0

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

add this to changelong and bump up the version. This seems like a major change? so may be jump to 2.0.0

I think maybe there is no need to add to changelog though 🤔 , thinking that we haven't changed the code, but only changed the CI test environment.

I bump up the version in docs only for making this requirement consistent to environment that can constantly pass tests.

So that is to say the library still works for python 3.7, but it is just no longer tested in CI going forward.

Do you think since this is an update in requirement, maybe it could still be a major change? Basically, we would no longer support any issues regarding seq2pat in python 3.7.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we changing the Test environment OR are we changing our Requirement?

Given the tests are failing with 3.7, it seems we are changing our Requirements to 3.8+ and revising test environment accordingly. It is a major change to move from one Python version to another, no?

I would expect a note in the Changelog, since anything 1.x.x is OK with 3.7 but anything 2.x.x is not OK with 3.7.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we changing the Test environment OR are we changing our Requirement?

Given the tests are failing with 3.7, it seems we are changing our Requirements to 3.8+ and revising test environment accordingly. It is a major change to move from one Python version to another, no?

I would expect a note in the Changelog, since anything 1.x.x is OK with 3.7 but anything 2.x.x is not OK with 3.7.

Thanks @skadio Yeah, we are changing both the test environment and requirement now, where they both drop 3.7 for consistency. It makes sense to update changelog and version. I will commit the changes and release new version.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we know what's causing the issue? 3.7 is not that old, so I am curious what broke.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh wait.. is it because GitHub Actions dropped mac support? So that means, our library actually runs on 3.7? Just that, our CI/CD tests cannot run it? But if our library can still work on 3.7, why are we jumping our requirement to 3.8? I am confused :D

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh wait.. is it because GitHub Actions dropped mac support? So that means, our library actually runs on 3.7? Just that, our CI/CD tests cannot run it? But if our library can still work on 3.7, why are we jumping our requirement to 3.8? I am confused :D

Yes, it is because GitHub Actions has this macos-latest image to drop 3.7, which is the image we use, then our CI test fails. To fix this, I drop 3.7 in test environment.

Then I hope to make the requirements consistent to the CI test environments, so I also change requirement to 3.8+. It is not an issue where seq2pat won't work on 3.7 though. We just won't have seq2pat tested in CI going forward.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh wait.. is it because GitHub Actions dropped mac support? So that means, our library actually runs on 3.7? Just that, our CI/CD tests cannot run it? But if our library can still work on 3.7, why are we jumping our requirement to 3.8? I am confused :D

And looks like 3.7 is already end-of-life now according to this page

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I see... so one option is to upgrade CD/CI to 3.8 but leave library requirement as 3.7. And the other option is; because we cannot test it anymore, to also jump library reqs to 3.8 as well.

Agree that you can jump the library too, to be consistent with what we can test. Thank you!

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I quikcly looked at other libs. TextWiser seems most problematic at 3.6. Selective and Jurity are also 3.7 that we can bump up. Can you communicate with KArthik on Textwiser, and I will take a look at the other two.

And one syntactic comment. Can you change the text from Python 3.8+ to Python 3.8+ to bold fonts, which is the case for all other libs

README.md Outdated
@@ -114,7 +114,7 @@ our [documentation](https://fidelity.github.io/seq2pat/installation.html).

### Requirements

The library requires ```Python 3.7+```, the ```Cython``` package, and a ```C++``` compiler.
The library requires ```Python 3.8+```, the ```Cython``` package, and a ```C++``` compiler.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we changing the Test environment OR are we changing our Requirement?

Given the tests are failing with 3.7, it seems we are changing our Requirements to 3.8+ and revising test environment accordingly. It is a major change to move from one Python version to another, no?

I would expect a note in the Changelog, since anything 1.x.x is OK with 3.7 but anything 2.x.x is not OK with 3.7.

README.md Outdated
@@ -114,7 +114,7 @@ our [documentation](https://fidelity.github.io/seq2pat/installation.html).

### Requirements

The library requires ```Python 3.7+```, the ```Cython``` package, and a ```C++``` compiler.
The library requires ```Python 3.8+```, the ```Cython``` package, and a ```C++``` compiler.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh wait.. is it because GitHub Actions dropped mac support? So that means, our library actually runs on 3.7? Just that, our CI/CD tests cannot run it? But if our library can still work on 3.7, why are we jumping our requirement to 3.8? I am confused :D

@@ -49,6 +49,23 @@ seq2pat.add_constraint(3 <= price.average() <= 4)
patterns = seq2pat.get_patterns(min_frequency=2)
```

### Mining Large Sequence Databases
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

new section added

@@ -2,4 +2,7 @@
# Copyright FMR LLC <[email protected]>
# SPDX-License-Identifier: GPL-2.0

__version__ = "1.4.0"
__author__ = "FMR LLC"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

adding these new fields

@@ -15,7 +15,7 @@ jobs:
runs-on: ${{ matrix.os }}
strategy:
matrix:
python-version: ['3.7', '3.8', '3.9', '3.10']
python-version: ['3.8', '3.9', '3.10', '3.11']
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@takojunior it seems "windows-latest" is failing installing a (some?) library. That's not sth we can fix easily assume. In this case, I am OK dropping windows testing. That's in line our jump to v2.0 where we drop support for Python 3.7 "and" "windows". May be remove windows and merge? Please add windows change to CHANGELOG as well

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Makes sense to me. I see the updates to CHANGELOG. I will update PyPI.

@skadio skadio merged commit 0d5a934 into master May 31, 2024
8 checks passed
@skadio skadio deleted the ci-fix branch May 31, 2024 20:49
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.

2 participants