This repository contains the platform-specific Adblock Plus source code for Chrome, Opera, Microsoft Edge and Firefox. It can be used to build Adblock Plus for these platforms, generic Adblock Plus code will be extracted from other repositories automatically (see dependencies file).
Note that the Firefox extension built from this repository is the new WebExtension. The source code of the legacy Adblock Plus extension can be found here.
- Mercurial or Git (whichever you used to clone this repository)
- Python 2.7
- The Jinja2 module (>= 2.8)
- For signed builds: PyCrypto module
- Node.js (>= 8.9)
On Windows, you need a Linux environment running on WSL. Then install the above requirements and run the commands below from within Bash.
Run one of the following commands in the project directory, depending on your target platform:
./build.py build -t chrome -k adblockpluschrome.pem
./build.py build -t edge
./build.py build -t gecko
This will create a build with a name in the form adblockpluschrome-1.2.3.nnnn.crx, adblockplusedge-1.2.3.nnnn.appx or adblockplusfirefox-1.2.3.nnnn.xpi.
Note that you don't need an existing signing key for Chrome, a new key will be created automatically if the file doesn't exist.
The Microsoft Edge build adblockplusedge-1.2.3.nnnn.appx is unsigned and is only useful for uploading into Windows Store, where it will be signed. For testing use the devenv build.
The Firefox extension will be unsigned, and therefore is mostly only useful for upload to Mozilla Add-ons. You can also load it for testing purposes under about:debugging or by disabling signature enforcement in Firefox Nightly.
To simplify the process of testing your changes you can create an unpacked development environment. For that run one of the following commands:
./build.py devenv -t chrome
./build.py devenv -t edge
./build.py devenv -t gecko
This will create a devenv.* directory in the repository. You can load the directory as an unpacked extension, under chrome://extensions in Chrome, under about:debugging in Firefox or in Extensions menu in Microsoft Edge, after enabling extension development features in about:flags. After making changes to the source code re-run the command to update the development environment. In Chrome and Firefox the extension should reload automatically after a few seconds.
Builds for Microsoft Edge do not automatically detect changes, so after rebuilding the extension you should manually force reloading it in Edge by hitting the Reload Extension button.
The build script calls the ensure_dependencies script automatically to manage the dependencies (see dependencies file). Dependencies with local modifications won't be updated. Otherwise during development specifying a feature-branch's name for a dependency's revision is sometimes useful. Alternatively dependency management can be disabled completely by setting the SKIP_DEPENDENCY_UPDATES environment variable, for example:
SKIP_DEPENDENCY_UPDATES=true ./build.py devenv -t chrome
To verify your changes you can use the unit test suite located in the qunit directory of the repository. In order to run the unit tests go to the extension's Options page, open the JavaScript Console and type in:
location.href = "qunit/index.html";
The unit tests will run automatically once the page loads.
There is also an external test runner that can be invoked from the command line in order to run the unit tests along some integration tests on different browsers, and automatically run the linter as well.
On Windows, in order to use the test runner, in addition to setting up a Linux environment as outlined above, you need to have Node.js installed in your native Windows environment. Then run the commands below from within PowerShell or cmd.exe (unlike when building the extension which needs to be done from Bash).
Make sure the required packages are installed and up-to-date:
npm install
Start the testing process for all browsers:
npm test
Start the testing process in one browser only:
npm test -- -g <Firefox|Chromium>
By default it downloads (and caches) and runs the tests against the oldest compatible version and the latest release version of each browser. In order to run the tests against a different version set the CHROMIUM_BINARY or FIREFOX_BINARY environment variables. Following values are accepted:
installed
- Uses the version installed on the system.
path:<path>
- Uses the binary located at the given path.
download:<version>
- Downloads the given version (for Firefox the version must be in the
form
<major>.<minor>
, for Chromium this must be the revision number).
- Downloads the given version (for Firefox the version must be in the
form
You can lint the code using ESLint.
You will need to setup first. This will install our configuration eslint-config-eyeo and everything needed after you run:
npm install
Then you can run to lint the code:
npm run lint