Skip to content

Commit

Permalink
Make manage workflow 'to setup' links intelligent (#2549)
Browse files Browse the repository at this point in the history
https://eaflood.atlassian.net/browse/WATER-4437

For context, we found out legacy background jobs scheduled in BullMQ only run intermittently. One we found hadn't run for the last 2 years so agreed to bin. Two we need to deal with at some point but intermittent is fine for now. The critical job, which is putting updated licences into workflow, we solved by migrating to [water-abstraction-system](DEFRA/water-abstraction-system#903).

As part of solving it we took the opportunity to add data to the workflow record to allow us to identify that the record was added because of an updated licence. We also spotted that our time-limited job was broken 😱 so [fixed that](DEFRA/water-abstraction-system#908) and updated it to _also_ add some info to the workflow record.

With these handy bits of info now in the workflow record, it seems a shame we don't make the reason why the record was added visible to the user.

So, this change amends the link in the 'To setup' based on that extra info. In the pre-handler that fetches the to-setup workflow records we now iterate through the results and add the link details to use in the view.

If it spots the `timeLimitedChargeVersionId` property we add to the data field it will generate a link that will take the user directly to the charge version with the time-limited element.

Else if the `chargeVersionExists` property is present we know the record was added by the licence updates job. If the property is true we direct the user to the charge information tab for the licence rather than drop them into a new one. That way they can see the existing ones and determine if a new one is needed.

Else if `chargeVersionExists` property is missing or false we leave the link as it was and direct the user to create a new charge version.
  • Loading branch information
Cruikshanks authored Apr 15, 2024
1 parent 53a1186 commit 3c7f0d2
Show file tree
Hide file tree
Showing 4 changed files with 31 additions and 6 deletions.
3 changes: 2 additions & 1 deletion src/internal/config.js
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,8 @@ module.exports = {
showVerificationCode: process.env.SHOW_VERIFICATION_CODE_FEATURE === 'true' && !isProduction,
showReturnRequirements: (get(process.env, 'SHOW_RETURN_REQUIREMENTS') || '').toLowerCase() === 'true' && !isProduction,
triggerSrocAnnual: (get(process.env, 'TRIGGER_SROC_ANNUAL') || '').toLowerCase() === 'true',
useNewBillRunSetup: (get(process.env, 'USE_NEW_BILL_RUN_SETUP') || '').toLowerCase() === 'true'
useNewBillRunSetup: (get(process.env, 'USE_NEW_BILL_RUN_SETUP') || '').toLowerCase() === 'true',
useWorkflowSetupLinks: (get(process.env, 'USE_WORKFLOW_SETUP_LINKS') || 'true').toLowerCase() === 'true'
},
billRunsToDisplayPerPage: process.env.BILL_RUNS_TO_DISPLAY_PER_PAGE || 20
}
24 changes: 24 additions & 0 deletions src/internal/modules/charge-information/pre-handlers.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ const moment = require('moment')
const { get, sortBy, isEmpty, pick } = require('lodash')
const { v4: uuid } = require('uuid')
const { flattenAdditionalChargesProperties } = require('./lib/mappers')

const { featureToggles } = require('../../config.js')

const errorHandler = (err, message) => {
if (err.statusCode === 404) {
return Boom.notFound(message)
Expand Down Expand Up @@ -205,6 +208,27 @@ const loadChargeVersionWorkflows = async request => {
const { toSetupPageNumber, reviewPageNumber, changeRequestPageNumber } = request.query
try {
const workflows = await services.water.chargeVersionWorkflows.getChargeVersionWorkflows(toSetupPageNumber, 100, 'to_setup')
workflows.data.forEach((workflow) => {
const { chargeVersionWorkflowId, data, licenceId } = workflow

if (featureToggles.useWorkflowSetupLinks && data?.timeLimitedChargeVersionId) {
workflow.link = {
href: `/licences/${licenceId}/charge-information/${data.timeLimitedChargeVersionId}/view`,
text: 'Time limited'
}
} else if (featureToggles.useWorkflowSetupLinks && data?.chargeVersionExists) {
workflow.link = {
href: `/licences/${licenceId}#charge`,
text: 'Updated'
}
} else {
workflow.link = {
href: `/licences/${licenceId}/charge-information/create?chargeVersionWorkflowId=${chargeVersionWorkflowId}`,
text: 'Set up'
}
}
})

return {
data: sortBy(workflows.data, chargeVersionWorkflowsOrder),
pagination: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@
<td class="govuk-table__cell">{{row.licenceHolderRole.company.name}}</td>
<td class="govuk-table__cell">{{row.licenceVersion.startDate | date}}</td>
<td class="govuk-table__cell">
<a href="/licences/{{row.licenceId}}/charge-information/create?chargeVersionWorkflowId={{row.chargeVersionWorkflowId}}">Set up</a>
{% if isReviewer %}
<a href="{{row.link.href}}">{{row.link.text}}</a>
{% if isReviewer %}
| <a href="/charge-information-workflow/{{row.chargeVersionWorkflowId}}/remove">Remove</a>
{% endif %}
</td>
Expand All @@ -40,4 +40,4 @@
There are no licences that require charge information setup.
</div>
{% endif %}
</div>
</div>
4 changes: 2 additions & 2 deletions test/internal/modules/charge-information/pre-handlers.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -349,8 +349,8 @@ experiment('internal/modules/charge-information/pre-handlers', () => {
expect(services.water.chargeVersionWorkflows.getChargeVersionWorkflows.called).to.be.true()
})
test('returns the results ordered by licence start date', async () => {
expect(result.data[0]).to.equal({ licence: { startDate: '2000-09-30' } })
expect(result.data[1]).to.equal({ licence: { startDate: '2002-05-03' } })
expect(result.data[0].licence).to.equal({ startDate: '2000-09-30' })
expect(result.data[1].licence).to.equal({ startDate: '2002-05-03' })
})
})
experiment('when the service response is invalid', () => {
Expand Down

0 comments on commit 3c7f0d2

Please sign in to comment.