diff --git a/README.md b/README.md index 7351eed..ab96c0b 100644 --- a/README.md +++ b/README.md @@ -1,201 +1,93 @@ -

WebPageTest Logo

+# WebPageTest Slack Action -

Learn about more WebPageTest API Integrations in our docs

- -# WebPageTest GitHub Action -[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](/LICENSE) - -WebPageTest's GitHub Action lets you automatically run tests against WebPageTest on code changes. You can set and enforce performance budgets, and have performance data automatically added to your pull requets to move the performance conversation directly into your existing development workflow. +WebPageTest's Slack Action lets you automatically run tests against WebPageTest. +You can set and enforce performance budgets, and have performance data automatically added to your Slack channel. **Features:** - Automatically run WebPageTest against code changes - Set and enforce budgets for any metric WebPageTest can surface (spoiler alert: there are a lot) - Complete control over WebPageTest test settings (authentication, custom metrics, scripting, etc) -- Automatically create comments on new pull requests with key metrics, waterfall and more. ## Using the Action -1. [Get a WebPageTest API Key](https://app.webpagetest.org/ui/entry/wpt/signup?enableSub=true&utm_source=docs&utm_medium=github&utm_campaign=ghactions&utm_content=account) and store it [as a secret in your repository's settings](https://docs.github.com/en/actions/reference/encrypted-secrets#creating-encrypted-secrets-for-a-repository). - -![WPT_API_KEY Secret in repo settings](/images/wpt-action-api-secret.png) - -2. Create a `.github/workflows/webpagetest-action.yml` file in your repository with the following settings: +1. Create a `.github/workflows/frontend-performance.yml` file in your repository with the following settings: ```yml -on: [pull_request] +name: Frontend performance tests + +on: + repository_dispatch: + types: [frontend-performance-test] jobs: - build: + frontend-performance-test: runs-on: ubuntu-latest - name: WebPageTest Action + steps: - - name: Checkout - uses: actions/checkout@v2 - - - name: WebPageTest - uses: WPO-Foundation/webpagetest-github-action@main + - uses: actions/checkout@v1 + - name: Mobile tests + uses: timhofman/webpagetest-github-action@main + id: run-wpt-mobile with: apiKey: ${{ secrets.WPT_API_KEY }} urls: | - https://example.com/ - https://example.com/about - label: 'GitHub Action Test' + https://www.paracord.nl/ + https://www.paracord.nl/paracord + label: 'Paracord mobile tests' + budget: 'wpt-budget-mobile.json' + wptOptions: 'wpt-options-mobile.json' GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} -``` - -3. Open a Pull Request. WebPageTest's GitHub Action will run in the background and post a comment on your PR. - -![Sample pull request comment](/images/wpt-action-sample-comment.png) - -## Configuration -By default, WebPageTest's GitHub Action will run tests whenever the event (pull_request, push, etc) you specify in your workflow is triggered. (We recommend `pull_request`). - -The tests will be run with the following WebPageTest settings: - -- Location: Dulles, VA -- Browser: Chrome on an emulated Moto G4 -- Connection Type: 4G connection -- Number of test run per URL: 3 -- First view only (no repeat views tested) -- The test results will be checked every **5** seconds, up to a limit of **240s**. If no results are returned by then, the test will timeout and fail. -- Each test will be labeled with the label you provide via the `label` input. - -However, WebPageTest is capable of going _very_ deep, and the GitHub Action provides a number of configuration settings to help fine-tune your tests and even fail a pull request if performance budgets aren't met. - -### Setting performance budgets -WebPageTest's GitHub Action uses the [WebPageTest API Wrapper for NodeJS](https://github.com/marcelduran/webpagetest-api) under the hood. The wrapper provides [test specs](https://github.com/marcelduran/webpagetest-api/wiki/Test-Specs) functionality that lets you set budgets on any of the metrics returned by the WebPageTest API. - -The GitHub Action lets you provide a path to a specs JSON file using the `budget` input. If a specs file is included, WebPageTest's GitHub Action will test the results against the budgets you've defined. If any budget isn't met, the tests will fail and you'll be provided with links to dig into the full WebPageTest results to see what was slowing things down. - -For example, given the following configuration: -```yml -on: [pull_request] + - name: Send Slack Message + uses: archive/github-actions-slack@v2.0.0 + id: send-message -jobs: - build: - runs-on: ubuntu-latest - name: WebPageTest Action - steps: - - name: Checkout - uses: actions/checkout@v2 - - - name: WebPageTest - uses: WPO-Foundation/webpagetest-github-action@main with: - apiKey: ${{ secrets.WPT_API_KEY }} - urls: | - https://example.com/ - https://example.com/about - label: 'GitHub Action Test' - budget: 'wpt-budget.json' - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + slack-function: send-message + slack-bot-user-oauth-access-token: ${{ secrets.SLACK_BOT_USER_OAUTH_ACCESS_TOKEN }} + slack-channel: speedcurve-demo + slack-text: "${{ steps.run-wpt-mobile.outputs.results }}" ``` +2. Secrets + +The WPT_API_KEY and GITHUB_TOKEN are secrets on the organization level, so you don't need to add anything to your repository. -And a `wpt-budget.json` file containing: +3. Budget and options files +Use the wptOptions to customize how you want to run the tests. ```json { - "median": { - "firstView": { - "firstContentfulPaint": 1000 - } - } + "runs": 1, + "location": "gce-europe-west4:Chrome;iPhone6", + "connectivity": "3G", + "emulateMobile": true } ``` -WebPageTest would test each run's First Contentful Paint. If the First Contentful Paint fires in less than 1 second, the test passes; if not, the test would fail. - -![Example of a WPT action failing the PR if a budget is exceeded](/images/wpt-action-fail-pr.png) - -The specs format provides tremendous flexiblity in which metrics you want to budget against. For more information, check out [the official documentation](https://github.com/marcelduran/webpagetest-api/wiki/Test-Specs). - -### Testing against a deployment URL -If you are going to set and enforce performance budgets, **make sure to pass a preview URL** to test against to make sure that you're testing against the latest changes, not against a prior version of your site. - -As an example, if you happen to be using a service like [Netlify](https://www.netlify.com/), they'll generate deploy previews for each PR. Here's an example of how you could run the WebPageTest action against the latest deploy preview using the [Wait for Netlify Action](https://github.com/JakePartusch/wait-for-netlify-action). - -```yml -on: [pull_request] - -jobs: - build: - runs-on: ubuntu-latest - name: WebPageTest Action - steps: - - name: Checkout - uses: actions/checkout@v2 - - - name: Wait for the Netlify Preview - uses: jakepartusch/wait-for-netlify-action@v1.2 - id: netlify - with: - site_name: 'your-netlify-site-name' - - - name: WebPageTest - uses: WPO-Foundation/webpagetest-github-action@main - with: - apiKey: ${{ secrets.WPT_API_KEY }} - urls: | - ${{ steps.netlify.outputs.url }} - ${{ steps.netlify.outputs.url }}/about - label: 'GitHub Action Test' - budget: 'wpt-budget.json' - wptOptions: 'wpt-options.json' - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} -``` - -_If you are testing against a Netlify deployment preview, it's important to note that the new collaborative features for their previews inject a full single-page application into your page, messing with any performance thresholds you might be trying to enforce. Add the following to your wptOptions JSON to make sure none of the extra code makes it into your test results_ - -``` -"block": "netlify-cdp-loader.netlify.app" -``` - -### Customizing your WebPageTest tests -There are a _lot_ of [options available in WebPageTest](https://github.com/marcelduran/webpagetest-api#test-works-for-runtest-method-only) to customize your test results, record custom metrics, or do advanced scripting and multi-page flows. - -To give you the ability to customize you tests, the WebPageTest GitHub Action let's you provide the path to a JSON object with your test options, using the `wptOptions` input. - -For example, given the following configuration: - -```yml -on: [pull_request] - -jobs: - build: - runs-on: ubuntu-latest - name: WebPageTest Action - steps: - - name: Checkout - uses: actions/checkout@v2 - - - name: WebPageTest - uses: WPO-Foundation/webpagetest-github-action@main - with: - apiKey: ${{ secrets.WPT_API_KEY }} - urls: | - https://example.com/ - https://example.com/about - label: 'GitHub Action Test' - budget: 'wpt-budget.json' - wptOptions: 'wpt-options.json' - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} -``` - -And a `wpt-options.json` file containing: - +You can also set budgets for a test. See 'budget' in the example. +A test will be marked in Slack when it exceeds the provided budgets ```json { - "runs": 1, - "location": "Dulles:Chrome", - "connectivity": "Cable", - "blockAds": true + "median": { + "firstView": { + "firstContentfulPaint": 1000 + } + } } ``` -The defaults values for the number of runs, location, and connectivity type would all be overwritten by the settings specified here. In addition, any ads defined by https://adblockplus.org/ would be automatically blocked. +4. Trigger manually or from Jenkins pipeline + +The action is triggered by the repository_dispatch event. +Our development pipeline is not (yet) fully running on Github Actions, the below +snippet can be used to manually trigger the event. You can also add the snippet as a separate build step 'execute shell' ---- - -

Learn about more WebPageTest API Integrations in our docs

+``` +curl --request POST \ +--url 'https://api.github.com/repos/timhofman/rd-webpagetest/dispatches' \ + --header 'authorization: Bearer ' \ + --data '{"event_type": "frontend-performance-test"}' +``` +5. Run mobile and desktop tests +You can run separate tests for mobile and desktop by duplicating the steps in your action file and provide it with separate budget and options files. \ No newline at end of file