Merge pull request #11249 from electron/upgrading-chromium-tweaks
Apply some of my summit notes to the upgrading-chrome docs.
This commit is contained in:
commit
2ad425955b
2 changed files with 87 additions and 59 deletions
|
@ -1,7 +1,6 @@
|
||||||
# Upgrading Chromium
|
# Upgrading Chromium
|
||||||
|
|
||||||
This document is meant to serve as an overview of what steps are needed
|
This is an overview of the steps needed to upgrade Chromium in Electron.
|
||||||
on each Chromium upgrade in Electron.
|
|
||||||
|
|
||||||
- Upgrade libcc to a new Chromium version
|
- Upgrade libcc to a new Chromium version
|
||||||
- Make Electron code compatible with the new libcc
|
- Make Electron code compatible with the new libcc
|
||||||
|
@ -10,68 +9,87 @@ on each Chromium upgrade in Electron.
|
||||||
- Update Electron docs if necessary
|
- Update Electron docs if necessary
|
||||||
|
|
||||||
|
|
||||||
## Upgrade `libcc` to a new Chromium
|
## Upgrade `libcc` to a new Chromium version
|
||||||
|
|
||||||
1. Get the code and initialize the project:
|
1. Get the code and initialize the project:
|
||||||
- ```sh
|
- ```sh
|
||||||
$ git clone git@github.com:electron/libchromiumcontent.git
|
$ git clone git@github.com:electron/libchromiumcontent.git
|
||||||
$ cd libchromiumcontent
|
$ cd libchromiumcontent
|
||||||
$ ./script/bootstrap -v```
|
$ ./script/bootstrap -v```
|
||||||
2. Find the new beta/stable Chromium version from [OmahaProxy](https://omahaproxy.appspot.com/).
|
2. Update the Chromium snapshot
|
||||||
3. Put it into the `libchromiumcontent/VERSION` file, then run `$ ./script/update`
|
- Choose a version number from [OmahaProxy](https://omahaproxy.appspot.com/)
|
||||||
|
and update the `VERSION` file with it
|
||||||
|
- This can be done manually by visiting OmahaProxy in a browser, or automatically:
|
||||||
|
- One-liner for the latest stable mac version: `curl -so- https://omahaproxy.appspot.com/mac > VERSION`
|
||||||
|
- One-liner for the latest win64 beta version: `curl -so- https://omahaproxy.appspot.com/all | grep "win64,beta" | awk -F, 'NR==1{print $3}' > VERSION`
|
||||||
|
- run `$ ./script/update`
|
||||||
|
- Brew some tea -- this may run for 30m or more.
|
||||||
- It will probably fail applying patches.
|
- It will probably fail applying patches.
|
||||||
4. Fix `*.patch` files in the `/patches` and `/patches-mas` folders.
|
3. Fix `*.patch` files in the `patches/` and `patches-mas/` folders.
|
||||||
5. (Optional) Run a separate script to apply patches (`script/update` uses it internally):
|
4. (Optional) `script/update` applies patches, but if multiple tries are needed
|
||||||
- `$ ./script/apply-patches`
|
you can manually run the same script that `update` calls:
|
||||||
- There is also another script `/script/patch.py` that could be more useful
|
`$ ./script/apply-patches`
|
||||||
- Check `--help` to learn how it works with `$ ./script/patch.py -h`
|
- There is a second script, `script/patch.py` that may be useful.
|
||||||
6. Run the build when all patches can be applied without errors
|
Read `./script/patch.py -h` for more information.
|
||||||
|
5. Run the build when all patches can be applied without errors
|
||||||
- `$ ./script/build`
|
- `$ ./script/build`
|
||||||
- If some patches are no longer compatible with the Chromium code, fix compilation errors.
|
- If some patches are no longer compatible with the Chromium code,
|
||||||
7. When build succeeds, create a `dist` for Electron
|
fix compilation errors.
|
||||||
|
6. When the build succeeds, create a `dist` for Electron
|
||||||
- `$ ./script/create-dist --no_zip`
|
- `$ ./script/create-dist --no_zip`
|
||||||
- It will create `dist/main` folder in the root of the libcc repo
|
- It will create a `dist/main` folder in the libcc repo's root.
|
||||||
- You will need it to build Electron.
|
You will need this to build Electron.
|
||||||
8. (Optional) Update script contents if there are errors resultant of some files being removed or renamed. (`--no_zip` prevents script from create `dist` archives, you don't need them.)
|
7. (Optional) Update script contents if there are errors resulting from files
|
||||||
|
that were removed or renamed. (`--no_zip` prevents script from create `dist`
|
||||||
|
archives. You don't need them.)
|
||||||
|
|
||||||
|
|
||||||
## Update Electron Code
|
## Update Electron's code
|
||||||
|
|
||||||
1. Get the code:
|
1. Get the code:
|
||||||
- ```sh
|
- ```sh
|
||||||
$ git clone git@github.com:electron/electron.git
|
$ git clone git@github.com:electron/electron.git
|
||||||
$ cd electron
|
$ cd electron
|
||||||
```
|
```
|
||||||
2. If you already have libcc built on you machine in its own repo, you need to tell Electron explicitly to use it:
|
2. If you have libcc built on your machine in its own repo,
|
||||||
|
tell Electron to use it:
|
||||||
- ```sh
|
- ```sh
|
||||||
$ ./script/bootstrap.py -v \
|
$ ./script/bootstrap.py -v \
|
||||||
--libcc_source_path <libcc_folder>/src \
|
--libcc_source_path <libcc_folder>/src \
|
||||||
--libcc_shared_library_path <libcc_folder>/shared_library \
|
--libcc_shared_library_path <libcc_folder>/shared_library \
|
||||||
--libcc_static_library_path <libcc_folder>/static_library
|
--libcc_static_library_path <libcc_folder>/static_library
|
||||||
```
|
```
|
||||||
- If you haven't yet built libcc but it's already supposed to be upgraded to a new Chromium, bootstrap Electron as usual
|
3. If you haven't yet built libcc but it's already supposed to be upgraded
|
||||||
|
to a new Chromium, bootstrap Electron as usual
|
||||||
`$ ./script/bootstrap.py -v`
|
`$ ./script/bootstrap.py -v`
|
||||||
- Ensure that libcc submodule (`vendor/libchromiumcontent`) points to a right revision
|
- Ensure that libcc submodule (`vendor/libchromiumcontent`) points to the
|
||||||
|
right revision
|
||||||
|
|
||||||
3. Set CLANG_REVISION in` script/update-clang.sh` to match the version Chromium is using.
|
4. Set `CLANG_REVISION` in `script/update-clang.sh` to match the version
|
||||||
|
Chromium is using.
|
||||||
- Located in `electron/libchromiumcontent/src/tools/clang/scripts/update.py`
|
- Located in `electron/libchromiumcontent/src/tools/clang/scripts/update.py`
|
||||||
|
|
||||||
4. Checkout Chromium if you haven't already:
|
5. Checkout Chromium if you haven't already:
|
||||||
- https://chromium.googlesource.com/chromium/src.git/+/{VERSION}/tools/clang/scripts/update.py
|
- https://chromium.googlesource.com/chromium/src.git/+/{VERSION}/tools/clang/scripts/update.py
|
||||||
- (Replace the `{VERSION}` placeholder in the url above to the Chromium version libcc uses.)
|
- (Replace the `{VERSION}` placeholder in the url above to the Chromium
|
||||||
5. Build Electron.
|
version libcc uses.)
|
||||||
|
6. Build Electron.
|
||||||
- Try to build Debug version first: `$ ./script/build.py -c D`
|
- Try to build Debug version first: `$ ./script/build.py -c D`
|
||||||
- You will need it to run tests
|
- You will need it to run tests
|
||||||
6. Fix compilation and linking errors
|
7. Fix compilation and linking errors
|
||||||
7. Ensure that Release build can be built too
|
8. Ensure that Release build can be built too
|
||||||
- `$ ./script/build.py -c R`
|
- `$ ./script/build.py -c R`
|
||||||
- Often the Release build will have different linking errors that you'll need to fix.
|
- Often the Release build will have different linking errors that you'll
|
||||||
- Some compilation and linking errors are caused by missing source/object files in the libcc `dist`
|
need to fix.
|
||||||
8. Update `./script/create-dist` in the libcc repo, recreate a `dist`, and run Electron bootstrap script once again.
|
- Some compilation and linking errors are caused by missing source/object
|
||||||
|
files in the libcc `dist`
|
||||||
|
9. Update `./script/create-dist` in the libcc repo, recreate a `dist`, and
|
||||||
|
run Electron bootstrap script once again.
|
||||||
|
|
||||||
### Tips for fixing compilation errors
|
### Tips for fixing compilation errors
|
||||||
- Fix build config errors first
|
- Fix build config errors first
|
||||||
- Fix fatal errors first, like missing files and errors related to compiler flags or defines
|
- Fix fatal errors first, like missing files and errors related to compiler
|
||||||
|
flags or defines
|
||||||
- Try to identify complex errors as soon as possible.
|
- Try to identify complex errors as soon as possible.
|
||||||
- Ask for help if you're not sure how to fix them
|
- Ask for help if you're not sure how to fix them
|
||||||
- Disable all Electron features, fix the build, then enable them one by one
|
- Disable all Electron features, fix the build, then enable them one by one
|
||||||
|
@ -86,20 +104,31 @@ Follow all the steps above to fix Electron code on all supported platforms.
|
||||||
|
|
||||||
## Updating Crashpad
|
## Updating Crashpad
|
||||||
|
|
||||||
If there are any compilation errors related to the Crashpad, it probably means you need to update the fork to a newer revision: see [Upgrading Crashpad](https://github.com/electron/electron/tree/master/docs/development/upgrading-crashpad.md) for instructions on how to do that.
|
If there are any compilation errors related to the Crashpad, it probably means
|
||||||
|
you need to update the fork to a newer revision. See
|
||||||
|
[Upgrading Crashpad](https://github.com/electron/electron/tree/master/docs/development/upgrading-crashpad.md)
|
||||||
|
for instructions on how to do that.
|
||||||
|
|
||||||
|
|
||||||
## Updating NodeJS
|
## Updating NodeJS
|
||||||
|
|
||||||
Upgrade `vendor/node` to the Node release that corresponds to the v8 version being used in the new Chromium release. See the v8 versions in Node on
|
Upgrade `vendor/node` to the Node release that corresponds to the v8 version
|
||||||
|
used in the new Chromium release. See the v8 versions in Node on
|
||||||
|
|
||||||
See [Upgrading Node](https://github.com/electron/electron/tree/master/docs/development/upgrading-node.md) for instructions on how to do this.
|
See [Upgrading Node](https://github.com/electron/electron/tree/master/docs/development/upgrading-node.md)
|
||||||
|
for instructions on this.
|
||||||
|
|
||||||
## Verify ffmpeg Support
|
## Verify ffmpeg support
|
||||||
|
|
||||||
Electron ships with a version of `ffmpeg` that includes proprietary codecs by default. A version without these codecs is built and distributed with each release as well. Each Chrome upgrade should verify that switching this version is still supported.
|
Electron ships with a version of `ffmpeg` that includes proprietary codecs by
|
||||||
|
default. A version without these codecs is built and distributed with each
|
||||||
|
release as well. Each Chrome upgrade should verify that switching this version
|
||||||
|
is still supported.
|
||||||
|
|
||||||
You can verify Electron's support for multiple `ffmpeg` builds by loading the following page. It should work with the default `ffmpeg` library distributed with Electron and not work with the `ffmpeg` library built without proprietary codecs.
|
You can verify Electron's support for multiple `ffmpeg` builds by loading the
|
||||||
|
following page. It should work with the default `ffmpeg` library distributed
|
||||||
|
with Electron and not work with the `ffmpeg` library built without proprietary
|
||||||
|
codecs.
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
|
@ -129,7 +158,7 @@ You can verify Electron's support for multiple `ffmpeg` builds by loading the fo
|
||||||
</html>
|
</html>
|
||||||
```
|
```
|
||||||
|
|
||||||
## Useful Links
|
## Useful links
|
||||||
|
|
||||||
- [Chrome Release Schedule](https://www.chromium.org/developers/calendar)
|
- [Chrome Release Schedule](https://www.chromium.org/developers/calendar)
|
||||||
- [OmahaProxy](http://omahaproxy.appspot.com)
|
- [OmahaProxy](http://omahaproxy.appspot.com)
|
||||||
|
|
|
@ -105,7 +105,7 @@ We need to generate a patch file from each patch applied to V8.
|
||||||
- `git commit patches/v8/`
|
- `git commit patches/v8/`
|
||||||
8. Update `patches/v8/README.md` with references to all new patches that have been added so that the next person will know which need to be removed.
|
8. Update `patches/v8/README.md` with references to all new patches that have been added so that the next person will know which need to be removed.
|
||||||
9. Update Electron's submodule references:
|
9. Update Electron's submodule references:
|
||||||
```sh
|
- ```sh
|
||||||
cd electron/vendor/node
|
cd electron/vendor/node
|
||||||
electron/vendor/node$ git fetch
|
electron/vendor/node$ git fetch
|
||||||
electron/vendor/node$ git checkout electron-node-vA.B.C
|
electron/vendor/node$ git checkout electron-node-vA.B.C
|
||||||
|
@ -114,12 +114,11 @@ We need to generate a patch file from each patch applied to V8.
|
||||||
electron/vendor/libchromiumcontent$ git checkout upgrade-to-chromium-X
|
electron/vendor/libchromiumcontent$ git checkout upgrade-to-chromium-X
|
||||||
electron/vendor/libchromiumcontent$ cd ../..
|
electron/vendor/libchromiumcontent$ cd ../..
|
||||||
electron$ git add vendor
|
electron$ git add vendor
|
||||||
electron$ git commit -m "update submodule references for node and libc"
|
electron$ git commit -m "update submodule referefences for node and libc"
|
||||||
electron$ git pso upgrade-to-chromium-62
|
electron$ git pso upgrade-to-chromium-62
|
||||||
electron$ script/bootstrap.py -d
|
electron$ script/bootstrap.py -d
|
||||||
electron$ script/build.py -c -D```
|
electron$ script/build.py -c -D
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
## Notes
|
## Notes
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue