Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add backwards compatibility - support for prototypes made in Version 6 of the kit #553

Merged
merged 6 commits into from
Jul 31, 2018

Conversation

joelanman
Copy link
Contributor

@joelanman joelanman commented Jul 17, 2018

Read the guidance

username/password: test/test

Download the zip

This approach isolates old prototypes in a separate folder (app/v6) served by a separate app (created in server.js).

This avoids any clash in Nunjucks templates between old and new, as the v6 app only has access to old v6 views, and the normal app only has access to new views.

Keeping all user code in app is a good thing, as anything outside (as in the old /lib/backwards-compatibility approach) would be lost if users follow our update instructions to delete everything outside of app.

If a route or page exists in both apps, the new app wins over the v6 app.

It only requires one manual change from users - to find and replace /public/ to /public/v6/ in their code.

This PR:

  • Adds old modules (Elements, Frontend Toolkit, GOV.UK Template)
  • Adds Gulp task to copy assets from app/v6/assets to /public/v6
  • Adds Gulp task to process sass in /app/v6/assets/sass by including Elements
  • Adds a v6App to server.js with its own Nunjucks environment, to avoid clash between new and old views.
  • Changes the matchRoutes function to use next, so a request for one app can fall through to the next app.
  • Adds error handling middleware, that we now need due to the use of next
  • Adds documentation on how to use backwards compatibility

@joelanman joelanman force-pushed the backwards-compatibility-2 branch from 5896412 to e663767 Compare July 17, 2018 16:33
@joelanman joelanman force-pushed the backwards-compatibility-2 branch 2 times, most recently from d15543a to 5a63a5c Compare July 18, 2018 09:23
@joelanman joelanman changed the title Do not merge - Add backwards compatibility - support for prototypes made in Version 6 of the kit Add backwards compatibility - support for prototypes made in Version 6 of the kit Jul 18, 2018
@joelanman joelanman force-pushed the backwards-compatibility-2 branch 2 times, most recently from 44cfbb1 to c3da12f Compare July 18, 2018 11:26
@joelanman
Copy link
Contributor Author

joelanman commented Jul 18, 2018

BUG: checked function is missing from the v6 Nunjucks environment

Copy link

@kr8n3r kr8n3r left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@joelanman joelanman force-pushed the backwards-compatibility-2 branch from fa4fbb5 to b25c933 Compare July 19, 2018 15:33
@joelanman joelanman changed the title Add backwards compatibility - support for prototypes made in Version 6 of the kit Do not merge - Add backwards compatibility - support for prototypes made in Version 6 of the kit Jul 19, 2018
@joelanman joelanman force-pushed the backwards-compatibility-2 branch 4 times, most recently from 1619b0a to 79980eb Compare July 24, 2018 11:25
@joelanman joelanman changed the title Do not merge - Add backwards compatibility - support for prototypes made in Version 6 of the kit Add backwards compatibility - support for prototypes made in Version 6 of the kit Jul 24, 2018
@dashouse
Copy link

Totally non-blocking comment – Only concern on my end is that some users may have the expectation that backwards compatibility will some how convert or map your old code to new things.

Is there any benefit in being explicit about that the old parts of your prototype will still be using GOV.UK Elements / Frontend Toolkit / Template or just see if it comes up?

@joelanman
Copy link
Contributor Author

@dashouse good point, the documentation does mention 'Updating your code' quite a lot, which implies the code isn't being converted. It's not come up with 2 or 3 people I've tested with so far, but totally open to suggestions if you have anything in mind?

@dashouse
Copy link

@joelanman If it's not come up with those users then that's a good sign. I was just thinking if you had the opportunity to ask people submitting old prototypes "what do you expect from compatibility mode?" it would be interesting to know...but it seems like that might have been covered 👍

Copy link
Member

@hannalaakso hannalaakso left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Tested with https://github.com/alphagov/temporary-event-notice-prototype and works well, I can view pages from the old and new prototype which is pretty cool 👍 Left a couple of small comments.


1. Make a note of your Prototype Kit version in **VERSION.txt** in your prototype folder.

1. Download the latest Prototype Kit and unzip it.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it make sense for this step to come after "Copy everything from the new Prototype Kit folder into your prototype folder."? It would make it clearer that the steps before these are all for the user's old prototype.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

excellent idea

server.js Outdated
@@ -18,8 +18,25 @@ const packageJson = require('./package.json')
const routes = require('./app/routes.js')
const utils = require('./lib/utils.js')

var useV6 = false
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It might be good to add a comment about what "v6" is here, or maybe just link to the changelog entry.

express: v6App,
noCache: true,
watch: true
})
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As these arguments are now set in three different places in the file, I wonder if we might want to have them as a shared variable to reduce duplication. But if the intention is to have the v6 code here for the short term only then the current approach is okay for me 🙂

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

good idea, but the express property is different in each one so I think this is tricky

@joelanman
Copy link
Contributor Author

joelanman commented Jul 25, 2018

Can we do something to support old unbranded?

Done

another thing I found - if anyone has been using the unbranded template, they’ll need to copy that from their original lib into the top level v6 folder (edited)
(I was just pulling directly from lib)

@joelanman joelanman mentioned this pull request Jul 25, 2018
@joelanman joelanman force-pushed the backwards-compatibility-2 branch from 8d66281 to 4bdc82c Compare July 31, 2018 13:38
@joelanman joelanman force-pushed the backwards-compatibility-2 branch from 4bdc82c to 3c2b7c3 Compare July 31, 2018 13:43
@joelanman joelanman merged commit 90a5341 into master Jul 31, 2018
@joelanman joelanman deleted the backwards-compatibility-2 branch July 31, 2018 14:25
@joelanman joelanman mentioned this pull request Jul 31, 2018
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants