Skip to content

Latest commit

 

History

History
89 lines (62 loc) · 4.22 KB

LAB.md

File metadata and controls

89 lines (62 loc) · 4.22 KB

💈 Lab 22 - Deploying only what changed

⏰ Estimated time: 20-25 minutes

📚 Learning outcomes:

  • Explore an advanced example of the nx affected by deploying only the affected apps on the main branch
  • Understand how to configure the base commit for the nx affected in a CD scenario


🏋️‍♀️ Steps :

In the previous labs, we set up automatic deployments. But every time we push to the main, we're always building and running the deployment scripts for ALL the apps in our workspace. As our repo grows, this is not scalable. We only want to build and deploy the apps that have changed, and need re-deploying.

  1. Update your deploy.yml file so that it builds only the affected apps, and deploys only the affected apps

    ⚠️ You can compare against the previous commit for now: --base=HEAD~1

  2. If you haven't already, ensure you run your "affected" commands in parallel

  3. Commit everything

  4. Now make a change just to the store. Maybe update the title again

    • Commit and push
    • Inspect your workflow on the GitHub actions tab - it should only be building and deploying whatever changed in the last commit: only the Store.


⛔ The problem now is that it's always comparing against the last commit:

  • Let's say I make some changes to the API (or AdminUI) over a few commits - and I don't push them.

  • Then I make one small change to the Store, commit it, and push it to the main.

  • Even though I've pushed lots of commits with changes to both the Store and the API (or AdminUI), because our CD Workflow is only looking at the last commit, it will only deploy the Store. 👎

    There is also the problem of potential failures 🧨

    Now our setup is simple: it just builds. But let's say we wanted to run the E2E tests again before deploying - just to be extra safe! In that case, if I change the API (or AdminUI) and push, the E2E tests might fail. So API (or AdminUI) will not get deployed. I then fix the E2E tests, but because the API (or AdminUI) does not depend on its E2E tests, the nx affected will not mark it for deployment. So even though we changed the API (or AdminUI), it did not get deployed.

💡 Solution: last successful commit!

  • If we constantly compare against the last commit where all the affected apps got succesfully deployed - we will never miss a deployment
  • In our case, "successfully deployed" means when our deploy.yml workflow completes without errors. That's a succesful commit!
  • Getting the last successful commit is different on each platform:

  1. Right after the npm-install step, let's trigger the action to get the last successful commit:

    - uses: bahmutov/npm-install@v1
    - uses: nrwl/nx-set-shas@v2
      with:
        main-branch-name: 'main' # remember to set this correctly

  2. You can now remove the base parameter from the affected as it will be now automatically read from the environment variables.

  3. Commit everything and push. Let it build. It should compare against the immediately previous commit (because your workflow ran against it, and it passed)

  4. Try to go through one of the problematic scenarios described above. It should now work, and it should build both the API (or AdminUI) and the Store (instead of just the Store)

Let's say I make some changes to the API (or AdminUI) over a few commits - and I don't push them. Then I make one small change to the Store, commit it, and push to main. Even though I've pushed lots of commits with changes to both the Store and the API (or AdminUI), because our CD Workflow is only looking at the last commit, it will only deploy the Store.


🎓If you get stuck, check out the solution