mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
21 lines
1.5 KiB
Markdown
21 lines
1.5 KiB
Markdown
### QA Migrations Guide
|
|
Migrations are needed to change top-level state data, this can be found in the browser's storage. This can look like removing specific keys/value pairs from state, changing objects to an array of objects, changing the name of a controller, etc.
|
|
|
|
Steps
|
|
1. Create a new MetaMask directory\* folder locally with the source files before the migration, and load it as an unpacked extension in Chrome\*. If the migration is in a pull request, then build the `develop` branch to load. If the migration is already in `develop`, get a commit before the migration was added to build.
|
|
|
|
data:image/s3,"s3://crabby-images/c89c1/c89c13040f7230df8baca10e02f462ccf8ca1992" alt="Load unpacked extension to chrome"
|
|
|
|
##### \* For migrations targeting specific features behind a feature flag add them appropriately to the `.metamaskrc` file before building.
|
|
##### \* In order for the "Load unpacked" button to be shown developer mode needs to be enabled.
|
|
|
|
2. Once the build has been loaded and state data has been initialized, ensure that the data in question that the migration targets is present in the local storage data.
|
|
|
|
data:image/s3,"s3://crabby-images/b5cf6/b5cf642933a797c5a875b4e8c79c6b58a435182e" alt="Chrome storage state"
|
|
|
|
3. To trigger the migration a build with the migration will need to replace the files in the directory where the extension is loaded from, and refresh the extension.
|
|
|
|
data:image/s3,"s3://crabby-images/4cdf5/4cdf5d3c9c426603b962ed865e6b0fdc9d1b90f4" alt="gif of replacing files and reloading the extension"
|
|
|
|
4. Ensure that the data has been changed/deleted/etc.
|