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

Automated version testing #360

Open
pmalacho-mit opened this issue May 31, 2024 · 0 comments
Open

Automated version testing #360

pmalacho-mit opened this issue May 31, 2024 · 0 comments

Comments

@pmalacho-mit
Copy link
Collaborator

pmalacho-mit commented May 31, 2024

As we scale up RAISE Playground extension development (enabling not only the development of new extensions, but also the improvement and expansion of existing extensions), we need a way to ensure our updates to existing extensions don't break already saved projects.

In order to do this, we need two distinct automated workflows (which can eventually be joined into a single workflow that runs via a github action):

  1. On a given branch, generate an sb3 project that sufficiently utilizes the blocks of an extension.
    • The definition of sufficiently might change over time, but at least to begin with it can simply be that all blocks are included in the saved project
  2. On a given branch (likely one that branches off from dev), load in an sb3` project that is assumed to be the output of workflow (1) based on a previous version of the extension under test. Assert that no errors in loading occur, and thus no 'breaking' changes have occurred as far as project loading is concerned.

In order to accomplish the above workflows, we should use something like playwright so that we can fully leverage the actual scratch-gui / scratch-vm saving and loading mechanisms.

To implement the above tests, you'll likely have a node script coordinate the following activities:

  • bundle the extension under test
  • build and serve the scratch-gui
  • have a playwright test that navigates to the served location and does things like:
    • probe for block information (you can set up some global 'hooks' in the framework code to likely make this easier -- and later we can think about how to only include this during test, like using a build flag)
    • interact with the DOM to drag in blocks, save/ load, things like that
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

No branches or pull requests

1 participant