Skip to content

fix: remove waffle flag to show Certificates menu#3066

Merged
bradenmacdonald merged 4 commits into
openedx:masterfrom
mitodl:anas/fix-hide-certificate-link
Jun 1, 2026
Merged

fix: remove waffle flag to show Certificates menu#3066
bradenmacdonald merged 4 commits into
openedx:masterfrom
mitodl:anas/fix-hide-certificate-link

Conversation

@Anas12091101

@Anas12091101 Anas12091101 commented May 20, 2026

Copy link
Copy Markdown
Contributor

Description

The Certificates link in the Settings menu was always visible regardless of the ENABLE_CERTIFICATE_PAGE configuration because the conditional used an OR (||) operator to check either the config value or the useNewCertificatesPage waffle flag (mapped to legacy_studio.certificates in the platform). A recent upstream change in openedx-platform made legacy_studio.certificates always return True, which meant the OR condition was always satisfied and operators could no longer hide the Certificates menu by setting ENABLE_CERTIFICATE_PAGE=false.

This PR removes the waffle flag requirement for the Certificates link to appear, restoring operator control over menu visibility. Additionally, the default value of ENABLE_CERTIFICATE_PAGE has been changed from 'false' to 'true' so that existing deployments that rely on the waffle flag continue to see the menu without needing to add a new config variable.

Useful information to include:

  • Which user roles will this change impact? Course Author
  • Include screenshots for changes to the UI (ideally, both "before" and "after" screenshots, if applicable).

Supporting information

Link to other information about the change, such as GitHub issues, or Discourse discussions.
Be sure to check they are publicly readable, or if not, repeat the information here.

Testing instructions

Manual Testing Steps

  1. Test: Certificates visible by default

    • Ensure .env.development has ENABLE_CERTIFICATE_PAGE=true (or remove the variable entirely — it now defaults to true).
    • Open any course in Studio (e.g., http://apps.local.openedx.io:2001/course/course-v1:edX+DemoX+Demo_Course).
    • Click the Settings dropdown in the header.
    • Expected: "Certificates" link is present.
  2. Test: Certificates hidden when config is false

    • Set ENABLE_CERTIFICATE_PAGE=false in .env.development.
    • Restart the dev server.
    • Open the same course and click Settings.
    • Expected: "Certificates" link is not present.
  3. Test: Certificates hidden when config is removed and default was relied upon

    • Remove the ENABLE_CERTIFICATE_PAGE line entirely from .env.development.
    • The default in index.jsx is now 'true', so certificates should appear.
    • Restart the dev server, open the course, click Settings.
    • Expected: "Certificates" link is present.
  4. Run automated tests

    npx jest src/header/hooks.test.tsx --no-coverage
    
    • Expected: All 24 tests pass.

Other information

Include anything else that will help reviewers and consumers understand the change.

  • Does this change depend on other changes elsewhere?
  • Any special concerns or limitations? For example: deprecations, migrations, security, or accessibility.

Best Practices Checklist

We're trying to move away from some deprecated patterns in this codebase. Please
check if your PR meets these recommendations before asking for a review:

  • Any new files are using TypeScript (.ts, .tsx).
  • Avoid propTypes and defaultProps in any new or modified code.
  • Tests should use the helpers in src/testUtils.tsx (specifically initializeMocks)
  • Do not add new fields to the Redux state/store. Use React Context to share state among multiple components.
  • Use React Query to load data from REST APIs. See any apiHooks.ts in this repo for examples.
  • All new i18n messages in messages.ts files have a description for translators to use.
  • Avoid using ../ in import paths. To import from parent folders, use @src, e.g. import { initializeMocks } from '@src/testUtils'; instead of from '../../../../testUtils'

@openedx-webhooks openedx-webhooks added the open-source-contribution PR author is not from Axim or 2U label May 20, 2026
@openedx-webhooks

Copy link
Copy Markdown

Thanks for the pull request, @Anas12091101!

This repository is currently maintained by @bradenmacdonald.

Once you've gone through the following steps feel free to tag them in a comment and let them know that your changes are ready for engineering review.

🔘 Get product approval

If you haven't already, check this list to see if your contribution needs to go through the product review process.

  • If it does, you'll need to submit a product proposal for your contribution, and have it reviewed by the Product Working Group.
    • This process (including the steps you'll need to take) is documented here.
  • If it doesn't, simply proceed with the next step.
🔘 Provide context

To help your reviewers and other members of the community understand the purpose and larger context of your changes, feel free to add as much of the following information to the PR description as you can:

  • Dependencies

    This PR must be merged before / after / at the same time as ...

  • Blockers

    This PR is waiting for OEP-1234 to be accepted.

  • Timeline information

    This PR must be merged by XX date because ...

  • Partner information

    This is for a course on edx.org.

  • Supporting documentation
  • Relevant Open edX discussion forum threads
🔘 Get a green build

If one or more checks are failing, continue working on your changes until this is no longer the case and your build turns green.

Details
Where can I find more information?

If you'd like to get more details on all aspects of the review process for open source pull requests (OSPRs), check out the following resources:

When can I expect my changes to be merged?

Our goal is to get community contributions seen and reviewed as efficiently as possible.

However, the amount of time that it takes to review and merge a PR can vary significantly based on factors such as:

  • The size and impact of the changes that it introduces
  • The need for product review
  • Maintenance status of the parent repository

💡 As a result it may take up to several weeks or months to complete a review and merge your PR.

@codecov

codecov Bot commented May 20, 2026

Copy link
Copy Markdown

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 95.55%. Comparing base (7138dfb) to head (e5ef2d3).

Additional details and impacted files
@@           Coverage Diff           @@
##           master    #3066   +/-   ##
=======================================
  Coverage   95.55%   95.55%           
=======================================
  Files        1393     1393           
  Lines       32999    32994    -5     
  Branches     7645     7641    -4     
=======================================
- Hits        31532    31529    -3     
- Misses       1401     1412   +11     
+ Partials       66       53   -13     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.
  • 📦 JS Bundle Analysis: Save yourself from yourself by tracking and limiting bundle sizes in JS merges.

@mphilbrick211 mphilbrick211 moved this from Needs Triage to Ready for Review in Contributions May 20, 2026
@bradenmacdonald

Copy link
Copy Markdown
Contributor

It sounds like the useNewCertificatesPage waffle flag has been deleted right? So shouldn't we remove all references to it entirely, and just use the ENABLE_CERTIFICATE_PAGE MFE config?

BREAKING CHANGE: The 'legacy_studio.certificates' waffle flag will no
longer be respected. The system will behave as if the flag is set to
false permanently.
~ openedx/openedx-platform@7aaeef3

See also #3063 which has a plan for removing most of the waffle flags, for the same reason.

@Anas12091101 Anas12091101 force-pushed the anas/fix-hide-certificate-link branch from 0e1e476 to e5ef2d3 Compare May 22, 2026 07:40
@Anas12091101 Anas12091101 changed the title fix: require both ENABLE_CERTIFICATE_PAGE config and waffle flag to show Certificates menu fix: remove waffle flag to show Certificates menu May 25, 2026
@bradenmacdonald

Copy link
Copy Markdown
Contributor

Set ENABLE_CERTIFICATE_PAGE=false in .env.development and restart.
Navigate directly to http://apps.local.openedx.io:2001/course/course-v1:edX+DemoX+Demo_Course/certificates.
Expected: Page should show a 404 or redirect (the route in CourseAuthoringRoutes.tsx also checks this config).

It's not a big deal, but this isn't working for me. It just shows a blank page (header and footer but nothing else).

Otherwise, this PR is ready to go. I'm also fine merging it as is, because the link is being hidden correctly.

jacobo-dominguez-wgu added a commit to WGU-Open-edX/frontend-app-authoring that referenced this pull request May 26, 2026
…Page flag references

These flags are being removed in openedx#3066 and should be treated as always true. Remove test scenarios for the disabled state and clean up mock overrides that set them to false.
jacobo-dominguez-wgu added a commit to WGU-Open-edX/frontend-app-authoring that referenced this pull request May 26, 2026
…Page flag references

These flags are being removed in openedx#3066 and should be treated as always true. Remove test scenarios for the disabled state and clean up mock overrides that set them to false.
jacobo-dominguez-wgu added a commit to WGU-Open-edX/frontend-app-authoring that referenced this pull request May 26, 2026
…Page flag references

These flags are being removed in openedx#3066 and should be treated as always true. Remove test scenarios for the disabled state and clean up mock overrides that set them to false.
@Anas12091101

Copy link
Copy Markdown
Contributor Author

Yep, my bad. I have removed that from the testing instructions. The behavior you're seeing is expected with the current implementation.

Other than that, the PR should be ready to merge.

@bradenmacdonald bradenmacdonald merged commit d5f43d3 into openedx:master Jun 1, 2026
7 checks passed
@github-project-automation github-project-automation Bot moved this from Ready for Review to Done in Contributions Jun 1, 2026
@bradenmacdonald

Copy link
Copy Markdown
Contributor

Thanks!

@bradenmacdonald

Copy link
Copy Markdown
Contributor

@Anas12091101 There is a test failure on master after merging this, probably from someone else's changes in the meantime. Could you please take a look?

@Anas12091101

Copy link
Copy Markdown
Contributor Author

Looking

jacobo-dominguez-wgu added a commit to WGU-Open-edX/frontend-app-authoring that referenced this pull request Jun 1, 2026
…Page flag references

These flags are being removed in openedx#3066 and should be treated as always true. Remove test scenarios for the disabled state and clean up mock overrides that set them to false.
jacobo-dominguez-wgu added a commit to WGU-Open-edX/frontend-app-authoring that referenced this pull request Jun 2, 2026
…Page flag references

These flags are being removed in openedx#3066 and should be treated as always true. Remove test scenarios for the disabled state and clean up mock overrides that set them to false.
bradenmacdonald pushed a commit that referenced this pull request Jun 3, 2026
* feat: adding permission validations from authz for files page for view, create, edit and delete

* test: adding tests to increase code coverage

* refactor(authz): remove duplicate hook and gate lock/unlock behind canEditFiles

- Remove useUserPermissionsWithAuthzCourse in favor of useCourseUserPermissions
  which provides the same functionality with better generic typing
- Migrate all consumers (CourseFilesTable, FilesPage, header hooks) to use
  useCourseUserPermissions with flat destructuring
- Hide Lock/Unlock option in FileMenu, MoreInfoColumn, and FileInfoModalSidebar
  when canEditFiles is false (course_auditor should not see lock/unlock)
- Add unit tests for lock/unlock visibility based on permissions
- Fix clipboard mock in tests using Object.defineProperty
- Update FilesPage.test.jsx mocks to match new flat return shape

* test: remove deprecated useNewCertificatesPage and useNewVideoUploadsPage flag references

These flags are being removed in #3066 and should be treated as always true. Remove test scenarios for the disabled state and clean up mock overrides that set them to false.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

open-source-contribution PR author is not from Axim or 2U

Projects

Status: Done

Development

Successfully merging this pull request may close these issues.

4 participants