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

[python-package][R-package] adapt to scikit-learn 1.6 testing changes, pin more packages in R 3.6 CI jobs #6718

Merged
merged 27 commits into from
Nov 15, 2024

Conversation

jameslamb
Copy link
Collaborator

@jameslamb jameslamb commented Nov 12, 2024

Fixes #6717, adapting lightgbm to the following changes in scikit-learn (currently visible in scikit-learn 1.6 nightlies).

from scikit-learn/scikit-learn#30122:

  • estimators must populate tags.estimator_type in the tags returns by __sklearn_tags__()
  • regressors must populate tags.regressor_tags with a non-None values
  • classifiers must populate tags.classifier_tags with a non-None values

from scikit-learn/scikit-learn#30149:

  • @parametrize_with_checks() ignores _xfail_checks in _more_tags() / __sklearn_tags__() on estimators... projects must now pass a function that generates a dictionary of xfailed checks to @parametrize_with_checks() in test code

Fixes #6719, pinning all the versions of dependencies installed in R 3.6 CI jobs to make those jobs more stable (see previous issues: #6442 (comment), #6434).

@jameslamb jameslamb changed the title WIP: [python-package] adapt to scikit-learn 1.6 testing changes WIP: [python-package] adapt to scikit-learn 1.6 testing changes, pin more packages in R 3.6 CI jobs Nov 12, 2024
@jameslamb jameslamb changed the title WIP: [python-package] adapt to scikit-learn 1.6 testing changes, pin more packages in R 3.6 CI jobs [python-package] adapt to scikit-learn 1.6 testing changes, pin more packages in R 3.6 CI jobs Nov 13, 2024
@jameslamb jameslamb marked this pull request as ready for review November 13, 2024 06:22
)

.install_packages(c(
"brio/brio_1.1.4.tar.gz" # nolint: non_portable_path
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

All of these hard-coded versions are the latest for which there's a package at https://cran.r-project.org/src/contrib/Archive. That provides a set of packages that were all working together as of a few days ago.

We shouldn't need to actively manage this list... this should be able to remain untouched (I hope) until we drop R 3 support and delete this script entirely.

Comment on lines +151 to +152
_sklearn_ClassifierTags = None
_sklearn_RegressorTags = None
Copy link
Collaborator

Choose a reason for hiding this comment

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

Why are these defined again here?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Because if an earlier ImportError happens, then this part above would never get evaluated:

    except ImportError:
        _sklearn_ClassifierTags = None
        _sklearn_RegressorTags = None

And then the from .compat imprt _sklearn_ClassifierTags in sklearn.py would fail. This is not new, just following the pattern that's existed in LightGBM for a long time (see all the other {something} = None above it).

Happy to consider something else if you have a recommendation for improving this!

Copy link
Collaborator

Choose a reason for hiding this comment

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

Oh yeah, sorry.

The first one is defined for scikit-learn<1.6 and the second when scikit-learn isn't installed.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

yeah exactly. No need to be sorry, it's confusing!

Copy link
Collaborator

@StrikerRUS StrikerRUS left a comment

Choose a reason for hiding this comment

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

Thank you very much for your hard exploration!
Just two minor suggestions.

tests/python_package_test/test_sklearn.py Outdated Show resolved Hide resolved
tests/python_package_test/test_sklearn.py Outdated Show resolved Hide resolved
Co-authored-by: Nikita Titov <nekit94-08@mail.ru>
@jameslamb jameslamb merged commit 4531ff5 into master Nov 15, 2024
49 checks passed
@jameslamb jameslamb deleted the ci/sklearn-tests branch November 15, 2024 02:35
@StrikerRUS StrikerRUS changed the title [python-package] adapt to scikit-learn 1.6 testing changes, pin more packages in R 3.6 CI jobs [python-package][R-package] adapt to scikit-learn 1.6 testing changes, pin more packages in R 3.6 CI jobs Nov 16, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
3 participants