This repository has been archived by the owner on Nov 4, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 254
fix: pytest-selenium, pytest-variables, pyjwkest dependency issues #3987
Merged
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Merged
7 tasks
julianajlk
approved these changes
Jun 15, 2023
pshiu
force-pushed
the
pshiu/REV-3587_EcommerceWorkerUpgrade
branch
from
June 20, 2023 02:02
7a6b45c
to
94b6c6f
Compare
There is a dependency conflict for pytest in pytest-selenium v3, which conflictingly requires both: - pytest v6: https://github.com/pytest-dev/pytest-selenium/blob/8e0a5d549049a1db353ead98bf0b46f8ef04e014/pyproject.toml#L46 - pytest-metadata latest (via pytest-html), whose latest 3.0.0 requires pytest v7: https://github.com/pytest-dev/pytest-metadata/blob/4f70f2ae74dc880772d445b1ee2cbe8d50bedcbd/pyproject.toml#L43 Pin pytest-selenium to v2 for now. This resolves `make upgrade` error: There are incompatible versions in the resolved dependencies: pytest (from -r requirements/e2e.in (line 6)) pytest<7.0.0,>=6.0.0 (from pytest-selenium==3.0.0->-r requirements/e2e.in (line 8)) pytest>=2.4.2 (from pytest-variables==1.9.0->pytest-selenium==3.0.0->-r requirements/e2e.in (line 8)) pytest>=7.0.0 (from pytest-metadata==3.0.0->pytest-html==3.2.0->pytest-selenium==3.0.0->-r requirements/e2e.in (line 8)) pytest>=5.0.0 (from pytest-timeout==2.1.0->-r requirements/e2e.in (line 9)) pytest>=2.7.3 (from pytest-base-url==1.4.2->pytest-selenium==3.0.0->-r requirements/e2e.in (line 8)) pytest (from pytest-randomly==3.12.0->-r requirements/e2e.in (line 7)) pytest!=6.0.0,>=5.0 (from pytest-html==3.2.0->pytest-selenium==3.0.0->-r requirements/e2e.in (line 8)) See pytest-dev/pytest-selenium#294 for potential upstream issue. Also, pytest-variables v3 deprecated _variables, which is used by other pytest v2 libraries:: https://github.com/pytest-dev/pytest-variables/blob/13f4b2e4620c682ae0856e03b11106ad3b6e6894/CHANGES.rst Pin pytest-variables to v2 for now. This resolves `make acceptance` error: AttributeError: 'Config' object has no attribute '_variables'
On `make acceptance`, we now have a ModuleNotFoundError for jwkest. Why: Library pyjwkest has been deprecated by edx-drf-extensions: openedx/edx-drf-extensions#345 But there was a hidden dependency of ecommerce acceptance tests on jwkest. Add pyjwkest (the providing package) explicitly into requirements/e2e.in. This is not optimal because our goal is to deprecate pyjwkest, but we would need to modify ecommerce's tests first to be pyjwkest-free before removing the library from ecommerce's dependencies.
pshiu
force-pushed
the
pshiu/REV-3587_EcommerceWorkerUpgrade
branch
from
June 20, 2023 02:02
94b6c6f
to
6297d8f
Compare
pshiu
changed the title
build: make upgrade & pin pytest-selenium to v2
fix: pytest-selenium, pytest-variables, pyjwkest dependency issues
Jun 20, 2023
ishahroz
reviewed
Jun 20, 2023
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM! Thank you Phil. :)
mobeenali12
pushed a commit
that referenced
this pull request
Jul 25, 2023
grmartin
added a commit
that referenced
this pull request
Aug 29, 2023
* build: Creating a missing workflow file `self-assign-issue.yml`. The .github/workflows/self-assign-issue.yml workflow is missing or needs an update to stay in sync with the current standard for this workflow as defined in the `.github` repo of the `openedx` GitHub org. * build: Creating a missing workflow file `add-remove-label-on-comment.yml`. The .github/workflows/add-remove-label-on-comment.yml workflow is missing or needs an update to stay in sync with the current standard for this workflow as defined in the `.github` repo of the `openedx` GitHub org. * build: Updating a missing workflow file `add-depr-ticket-to-depr-board.yml`. The .github/workflows/add-depr-ticket-to-depr-board.yml workflow is missing or needs an update to stay in sync with the current standard for this workflow as defined in the `.github` repo of the `openedx` GitHub org. * docs: Remove repo specific CONTRIBUTING.rst We now have a org wide CONTRIBUTING.md that points to our correct general contributing guidelines. We don't need repo specific ones that forward to other contributing docs. * fix: account for refunds in exec ed 2u redemption flow (#3920) * chore: add logging to include fulfillment details upon GEAG allocation exception * chore: quality * fix: Pick the right purchase from ios response (#3921) * fix: Pick the right purchase from ios response iOS response contain multiple purchases, instead of picking the first purchase, pick the one which have given product id and latest date. LEARNER-9261 * feat: Added Android refund api (#3922) * feat: Added Android refund api Like Apple android doesn't have callback for every refund. Therefore we have created an endpoint which we will hit daily through ecommerce worker. Learner-9149 * feat: Error if products in basket are already purchased (#3929) * feat: Error if products in basket are already purchased * refactor: Add tests, Improve error message * refactor: Update docstring * test: Increase coverage * chore: add logging to debug ent-6954 (#3931) * fix: Fix error in checkout api for mobile (#3934) * fix: Fix error in checkout api for mobile * fix: Return error in case of duplicate transaction_id for mobile (#3936) * fix: Return error in case of duplicate transactionID for mobile * refactor: Review feedback, add documentation * feat: Added course and expires field in product form on ecommerce dashboard (#3938) Forked catalogue app from oscar and added course and expire field in ProductForm. This change will enable to add Android sku from a same dashboard page. * fix: reorder JWT decoders (#3941) Reordered the JWT decoders to first use the standard library version, and then use the custom ecommerce decoder which uses multiple issuers. In this way, we can see if any JWTs cannot be decoded by that standard library version, and when and if we are ready to retire the custom JWT decoding code. See DEPR openedx/public-engineering#83 * fix: cached monitoring (#3942) Monitoring features such as use of the increment method, to increment a custom attribute, requires the CachedCustomMonitoringMiddleware. This has been added so the earlier calls to increment will function. * feat: add discount_jwt monitoring (#3944) Add monitoring for the discount JWT. * feat: Added data_share_consent field to order fullfillment notes (#3939) Co-authored-by: IrfanUddinAhmad <[email protected]> * chore: Switch from edx-sphinx-theme to sphinx-book-theme The edx-sphinx theme is being deprecated, and replaced with sphinx-book-theme. This removes references to the deprecated theme and replaces them with the new standard theme for the platform. * test: Add tests for Mobile IAP (#3937) * test: Add tests for mobile In-app purchases This reverts commit 54ea975. * fix: fix codecov error Codecov PyPI package was removed on 12 April and the recommended step is to migrate to codecov Github Action instead. * fix: add an exec ex 2u max application check to the checkout flow. ENT-7059 Also removes codecov from ci.yml workflow. * feat: add product entitlement info api (#3945) * fix: Updated format for data_share_consent field * docs: Update the contributing guidelines link. We're moving towards a single set of guidelines org-wide. * feat!: remove custom JWT decoding (#3943) * feat!: remove custom JWT decoding Removes the ecommerce custom JWT decoding, and replaces with the simple decoding from the edx-drf-extensions library. * fix: drop constraints and make upgrade * fix: handle major upgrade of django-crispy-forms The major upgrade of django-crispy-forms called for some changes related to bootstrap3 and dependencies. See https://github.com/django-crispy-forms/django-crispy-forms/blob/main/CHANGELOG.md#major-changes-and-migration-guide * fix: code coverage reporting Codecov no longer exists on PyPI, so switch to github action to run coverage report. --------- Co-authored-by: Muhammad Zubair <[email protected]> * fix: Course to have multiple seats with certificate_type attribute (#3950) * fix: Course to have multiple seats with certificate_type attribute * refactor: Modify SKU generation hash, add tests * test: Modify tests * temp: update JWT_DECODE_HANDER in devstack.py Jenkins job for building devstack images is temporarily broken. This should fix the devstack settings until this configuration change lands in an updated image: openedx-unsupported/configuration#6921 * feat: add native Dockerfile to create ansible free image * feat: add additional fields to EnterpriseLearnerOfferApiSerializer (#3963) * refactor: add logging to mobile IAP (#3962) * refactor: Improve exception handling for mobile IAP (#3969) * refactor: Improve exception handling for mobile IAP * refactor: pylint fixes * feat: Fix capture_context error on Payment MFE (#3965) * feat: Fix capture_context error on Payment MFE * feat: removed whitespace * feat: removed whitespace * feat: modified test case * feat: modified test case --------- Co-authored-by: Muhammad Zubair <[email protected]> * feat: Add enterprise_customer_name in the event metadata for offer usage braze emails. (#3972) * feat: Embargo check for subscription Programs (#3960) * fix: Enable TrackingMiddleware for Mobile IAP basket (#3977) * chore: updated Python requirements (edx-ecommerce-worker to version 3.3.3) (#3968) Co-authored-by: Muhammad Zubair <[email protected]> * fix: schedule upgrade-python-requirements monthly * fix: add edx-revenue-tasks to user_reviewers & remove team_reviewers Will create a Jira ticket instead of tagging all the members of @openedx/revenue-squad. * feat: add sf line item field to enterprise offers ENT-7013 * feat: Added ios refund callback (#3967) * feat: add SDN endpoints (#3985) * feat: add endpoint to run SDN check and return counts * feat: add SDNCheckFailure REST APi * fix: fix 500 on SDN for subscriptions (#3989) * fix: fix 500 on SDN for subscriptions * fix: pytest-selenium, pytest-variables, pyjwkest dependency issues (#3987) * feat: add coupon sf opp line item attribute * feat: Store price and currency for Mobile IAP (#3992) * feat: Store price and currency for mobile IAP * fix: return 200 on embargo failure to prevent downstream error (#3993) * feat: Make mobile IAP execute/ API atomic (#3995) * chore: added CODEOWNERS file (#3970) * refactor: Add logging to mobile IAP checkout/ API (#4000) * chore: django security patch 3.2.20 upgrade (#3999) * feat: Updates opportunity line item regex and tests (#3996) * feat: unenroll refunded android users daily (#4015) * feat: unenroll refunded android users daily Django management command to un-enroll refunded android users. This command will be run by Jenkins job daily. * feat: mail mobile team for a mobile course change in publisher (#4014) * feat: mail mobile team for a mobile course change in publisher This will fix any unknown change from publisher to a course having mobile seats. After this fix mobile team will see mail and adjust price of the course on playstore or appstore. In the longer run we want to replace this solution by changing the course price directly using mobile platform apis. LEARNER-9377 * fix: fixed coverage issue --------- Co-authored-by: Feanil Patel <[email protected]> Co-authored-by: Adam Stankiewicz <[email protected]> Co-authored-by: jawad khan <[email protected]> Co-authored-by: Moeez Zahid <[email protected]> Co-authored-by: Robert Raposa <[email protected]> Co-authored-by: irfanuddinahmad <[email protected]> Co-authored-by: IrfanUddinAhmad <[email protected]> Co-authored-by: Kshitij Sobti <[email protected]> Co-authored-by: Mohammad Ahtasham ul Hassan <[email protected]> Co-authored-by: Alex Dusenbery <[email protected]> Co-authored-by: Muhammad Zubair <[email protected]> Co-authored-by: Soban Javed <[email protected]> Co-authored-by: Jade Olivier <[email protected]> Co-authored-by: Saleem Latif <[email protected]> Co-authored-by: Shahroz Ahmad <[email protected]> Co-authored-by: Phillip Shiu <[email protected]> Co-authored-by: Phillip Shiu <[email protected]> Co-authored-by: Hamzah Ullah <[email protected]> Co-authored-by: jawad khan <[email protected]> Co-authored-by: Chris Pappas <[email protected]> Co-authored-by: Usama Sadiq <[email protected]>
christopappas
pushed a commit
that referenced
this pull request
Dec 4, 2023
Sign up for free
to subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
make upgrade
Original reason for PR: Bump edx-ecommerce-worker to 3.3.4.
pin
pytest-selenium
to v2There is a dependency conflict [potential upstream issue] for pytest in pytest-selenium v3, which requires both:
Pin pytest-selenium to v2 for now.
Details of `make upgrade` error resolved by pin
pin
pytest-variables
to v2pytest-variables v3 deprecates _variables, which is used by other pytest v2 libraries: see [changelog]
Pin pytest-variables to v2 for now.
This resolves
make acceptance
error:add pyjwkest to e2e.in
On
make acceptance
, we now have aModuleNotFoundError
for jwkest.Why: Library pyjwkest has been deprecated by edx-drf-extensions: openedx/edx-drf-extensions#345
But there was a hidden dependency of ecommerce acceptance tests on jwkest.
Add pyjwkest (the providing package) explicitly into requirements/e2e.in.
This is not optimal because our goal is to deprecate pyjwkest, but we would need to modify ecommerce's tests first to be pyjwkest-free before removing the library from ecommerce's dependencies.
Additional Information