Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

  • The admin username is openedx and the password is the same. If you want to secure your sandbox’s data against public access, then change the admin password. You should also be able to create unprivileged user accounts as necessary.

  • The sandbox will redeploy every ~15 minutes if either of the following conditions are met:

    • The PR’s latest commit hash has changed

    • The PR’s Settings or Tutor Requirements sections have changed

  • The sandbox will be destroyed after ~15 minutes if either of the following conditions are met:

    • The create-sandbox label has been removed

    • The PR is merged or closed

  • When the sandbox redeploys, its database is preserved. To fully destroy and recreate with a fresh db, you will need a workaround:

    • Remove the create-sandbox label

    • Wait ~15 minutes

    • Check that the sandbox has been destroyed by going to the LMS. You should see a message like “This site is being provisioned”.

    • Put the create-sandbox label back

  • If your edx-platform branch (or the configured EDX_PLATFORM_VERSION) has migration changes that are incompatible with migrations that have already been applied to the sandbox’s db, then you will need to fully destroy and recreate with a fresh db (see above). A couple ways this can happen: force-pushing a modified migration; switching the base branch from master to <release>.master or vice-versa.

  • Idle sandboxes will be destroyed after weeks of inactivity. You can bring them back to life by pushing a new commit or rebasing your PR.

  • We have a usage budget for about 30 running instances. OpenCraft will let us know if we’re bumping up against that.

  • PRs to master/main will use Tutor Nightly. PRs to named release branches will use the latest patch release of the corresponding Tutor version (e.g., Quince → tutor>=17,<18). The Tutor version can be overridden using the Tutor Requirements section, as explained in the docs.

Known issues & wishes

Axim engineers, as you encounter things about the sandboxes that you wish could be improved, add them here. For items that seem like bugs, also ping in #grove-pr-watcher.

...

More access

  • to application logs (Need to have)

  • to the box itself via ssh (Nice to have)

...

Better status communication

  • Always fail loudly. That is: when you request a sandbox, something should happen. Either you should get a sandbox, or get a failure notification. No ghosting! 👻 This is true about 80% of the time now, but that 20% is enough to shake our confidence in the system as a whole.

    • Note: We used to have comments for this, but turned them off because they were too noisy. Would there be a less noisy way of notifying?

    • Idea: Use the GitHub checks system rather than bot comments

    • Idea: Configurable notification levels

    • Idea: Use one comment, and amend it to the update the status over time

  • Dashboard of existing sandboxes.

...

More examples in the docs on how to do complex configuration, including

  • MFE config

  • Waffle flags

  • Custom MFEs

  • Using branches/tags of Tutor plugins

  • Site configuration (broken link in tutor-contrib-grove)

...

More controls

  • Ability to fully destroy and recreate the sandbox without using the remove-label-wait-and-put-it-back workaround described above.

  • Ability to force a redeploy without pushing a commit. This can be desirable when a change is pushed to a dependency other than the PR itself (e.g. a Tutor branch).

...

Auto-provisioned data

  • openedx-demo-course, with configuration fork/branch

  • openedx-test-course, with configuration fork/branch

Auto-deploy from a tag or branch without having to have a PR

...

master

...

release branches

...

Scope for PR sandbox improvement discovery (Jan 2025)

In priority order, here are the PR sandbox improvements Axim is interested in having scoped out:

  1. Better status communication (via GitHub checks?)

    • We need to be immediately notified when a sandbox rebuild has been triggered.

      • By corollary, a developer should understand that if NOTHING HAPPENS, then no sandbox is building, and no sandbox will build.

      • This should all be true even if the code or the sandbox configuration is completely messed up. Fail quickly and loudly!

    • At the same time, we do not want to overwhelm folks who are subscribed to the PR with notifications. 3 GitHub comments per push is not acceptable.

    • Proposed solution: As a replacement to the current PR comment… have the PR sandbox build create a GitHub status check, which shows the status of the build (pending, in progress, failed, success) and links out to a status page which includes:

      • the deployment logs,

      • the deployment config, and

      • links to LMS, Studio, LMS admin and CMS admin.

      • [Stretch/Nice-to-have] Buttons to (a) update the sandbox and (b) destroy and recreate the sandbox.

      • Examples like the proposed solution: Netlify, Vercel

    • Whatever you come up with, we will want to continue to be able to view a list of existing sandboxes. Today, we can do this easily by searching the openedx org for the create-sandbox label. If the label remains, then this task is a no-op. If you get rid of the label, then we would need an alternative approach.

  2. More access

    • We need access to application logs.

    • We would like certain Axim engineers to be able to have SSH access to the boxes.

  3. Easier installation of Tutor plugins

    • Installing or modifying Tutor plugins is a very common use-case. One problem right now is that specifying the “Tutor requirements” list in the PR description will wholesale replace the default Tutor requirements, thus leaving the sandbox broken if the user doesn’t know to specify the right base requirements (tutor-contrib-grove, tutor-contrib-s3, etc.)

    • Example…

      • The user of this PR’s sandbox wanted just to install a patched version of Tutor:

        • Code Block
          git+https://github.com/brian-smith-tcril/tutor.git@nightly-node18-patched
      • In order to get the sandbox working, they had to repeatedly edit the requirements list via trial-and-error until they finally got a working box by specifying:

        • Code Block
          git+https://github.com/brian-smith-tcril/tutor.git@nightly-node18-patched
          git+https://github.com/overhangio/tutor-mfe.git@nightly
          git+https://gitlab.com/opencraft/dev/tutor-contrib-grove.git@main
          git+https://github.com/hastexo/tutor-contrib-s3.git@main
          git+https://github.com/overhangio/tutor-forum.git@nightly
    • Ideas:

      • Make the “Tutor requirements” list act as a list of requirement overrides and additions rather than a wholesale replacement of the default requirements list.

      • Have a consolidated single “tutor-contrib-pr-sandbox” requirement which transitively installs tutor, grove, s3, and anything else that the sandbox needs.

      • As a last resort… make the docs extremely clear and up-to-date regarding which base requirements need to be included.

  4. More examples in the docs

    • Grove configuration is very powerful, but it can be confusing how to interact with the different layers (Grove, Tutor, Open edX) and accomplish various common tasks. Particularly, we need an example of a PR or PRs which:

      • Overrides a Waffle flag

      • Overrides a value in MFE_CONFIG

      • Enables a new custom micro-frontend

      • Points to a fork/branch of an existing micro-frontend

      • Adds a custom Tutor plugin

      • Point to a fork/branch of an existing Tutor plugin

      • Uses site configuration

      • Uses a custom brand

  5. Auto-provisioned data

    • We’d like each instance to be pre-provisioned with:

      • A list of course runs to import, each specified by:

        • an Org, Course, and Run

        • a URL to a tar.gz file

        • By default, this list should include one item:

          • Code Block
            - org: OpenedX
              course: DemoX
              run: DemoCourse
              url: https://github.com/openedx/openedx-test-course/blob/master/dist/test-course.tar.gz
      • A user instructor@openedx.org (PW=instructor) who is an instructor in all courses

      • A user learner@openedx.org (PW=learner) who is enrolled in all courses

      • Note: We do not necessarily need the demo library to be imported.