diff --git a/server/models/views/lib/find-min-threshold.js b/server/models/views/lib/find-min-threshold.js
new file mode 100644
index 000000000..4df7cf444
--- /dev/null
+++ b/server/models/views/lib/find-min-threshold.js
@@ -0,0 +1,37 @@
+function getMinFromType (arr, type) {
+ const filtered = arr.filter(item => item.threshold_type === type)
+ if (filtered.length) {
+ return filtered.reduce((min, curr) => parseFloat(curr.value) < parseFloat(min.value) ? curr : min)
+ }
+ return null
+}
+
+function findMinValueByLogic (arr, type) {
+ if (type === 'A') {
+ // Logic for Type A
+ return getMinFromType(arr, 'FW RES FAL') ||
+ getMinFromType(arr, 'FW ACT FAL') ||
+ getMinFromType(arr, 'FW ATCON FAL')
+ } else if (type === 'W') {
+ // Logic for Type W
+ return getMinFromType(arr, 'FW RES FW') ||
+ getMinFromType(arr, 'FW ACT FW') ||
+ getMinFromType(arr, 'FW ATCON FW')
+ }
+ return null
+}
+
+function filterImtdThresholds (imtdThresholds) {
+ const typeA = imtdThresholds.filter(item => item.fwis_type === 'A')
+ const typeW = imtdThresholds.filter(item => item.fwis_type === 'W')
+
+ const minObjectA = findMinValueByLogic(typeA, 'A')
+ const minObjectW = findMinValueByLogic(typeW, 'W')
+
+ return {
+ alert: minObjectA ? minObjectA.value : null,
+ warning: minObjectW ? minObjectW.value : null
+ }
+}
+
+module.exports = filterImtdThresholds
diff --git a/server/models/views/station.js b/server/models/views/station.js
index 39cf8a481..622cffb57 100644
--- a/server/models/views/station.js
+++ b/server/models/views/station.js
@@ -1,4 +1,3 @@
-// const hoek = require('@hapi/hoek')
const moment = require('moment-timezone')
const config = require('../../config')
const severity = require('../severity')
@@ -7,6 +6,7 @@ const Forecast = require('./station-forecast')
const util = require('../../util')
const tz = 'Europe/London'
const processImtdThresholds = require('./lib/process-imtd-thresholds')
+const filterImtdThresholds = require('./lib/find-min-threshold')
class ViewModel {
constructor (options) {
@@ -31,7 +31,6 @@ class ViewModel {
trend: river.trend
})
// Group warnings/alerts by severity level
-
const warningsAlertsGroups = util.groupBy(warningsAlerts, 'severity_value')
const numAlerts = warningsAlertsGroups['1'] ? warningsAlertsGroups['1'].length : 0
const numWarnings = warningsAlertsGroups['2'] ? warningsAlertsGroups['2'].length : 0
@@ -248,8 +247,12 @@ class ViewModel {
})
}
+ this.imtdThresholds = imtdThresholds?.length > 0
+ ? filterImtdThresholds(imtdThresholds)
+ : []
+
const processedImtdThresholds = processImtdThresholds(
- imtdThresholds,
+ this.imtdThresholds,
this.station.stageDatum,
this.station.subtract,
this.station.post_process
diff --git a/test/data/forcastStationModelData.json b/test/data/forcastStationModelData.json
index 919ed1b98..465211408 100644
--- a/test/data/forcastStationModelData.json
+++ b/test/data/forcastStationModelData.json
@@ -4,6 +4,7 @@
"ffoi_station_threshold_id": 507,
"ffoi_station_id": 87,
"fwis_code": "062WAF28Mimmshal",
+ "fwis_type": "FW ACTCON FAL",
"value": 0.96,
"fwa_name": "Mimmshall Brook",
"fwa_type": "a",
@@ -13,6 +14,7 @@
"ffoi_station_threshold_id": 508,
"ffoi_station_id": 87,
"fwis_code": "062WAF28UpColne",
+ "fwis_type": "FW ACTCON FAL",
"value": 2.3,
"fwa_name": "Upper River Colne and Radlett Brook",
"fwa_type": "a",
@@ -22,6 +24,7 @@
"ffoi_station_threshold_id": 509,
"ffoi_station_id": 87,
"fwis_code": "062FWF28Warrengt",
+ "fwis_type": "FW ACTCON FW",
"value": 2.24,
"fwa_name": "Mimmshall Brook at Warrengate Road",
"fwa_type": "w",
@@ -31,6 +34,7 @@
"ffoi_station_threshold_id": 510,
"ffoi_station_id": 87,
"fwis_code": "062FWF28CHeath",
+ "fwis_type": "FW ACTCON FAL",
"value": 2.7,
"fwa_name": "River Colne at Colney Heath",
"fwa_type": "w",
@@ -88,4 +92,4 @@
}
]
}
-}
\ No newline at end of file
+}
diff --git a/test/data/stationForecastData.json b/test/data/stationForecastData.json
index 70e7e94b0..e753acc45 100644
--- a/test/data/stationForecastData.json
+++ b/test/data/stationForecastData.json
@@ -48,6 +48,7 @@
"ffoi_station_threshold_id":507,
"ffoi_station_id":87,
"fwis_code":"062WAF28Mimmshal",
+ "fwis_type": "FW ACTCON FAL",
"value":0.96,
"fwa_name":"Mimmshall Brook",
"fwa_type":"a",
@@ -57,6 +58,7 @@
"ffoi_station_threshold_id":508,
"ffoi_station_id":87,
"fwis_code":"062WAF28UpColne",
+ "fwis_type": "FW ACTCON FAL",
"value":2.3,
"fwa_name":"Upper River Colne and Radlett Brook",
"fwa_type":"a",
@@ -66,6 +68,7 @@
"ffoi_station_threshold_id":509,
"ffoi_station_id":87,
"fwis_code":"062FWF28Warrengt",
+ "fwis_type": "FW ACTCON FW",
"value":2.24,
"fwa_name":"Mimmshall Brook at Warrengate Road",
"fwa_type":"w",
@@ -75,6 +78,7 @@
"ffoi_station_threshold_id":510,
"ffoi_station_id":87,
"fwis_code":"062FWF28CHeath",
+ "fwis_type": "FW ACTCON FAL",
"value":2.7,
"fwa_name":"River Colne at Colney Heath",
"fwa_type":"w",
@@ -297,5 +301,60 @@
"geometry":"{\"type\":\"Point\",\"coordinates\":[-3.03674273776571,53.8811798090409]}"
}
],
- "imtdThresholds": { "alert": "44.91", "warning": "43.91" }
+ "imtdThresholds": [
+ {
+ "station_threshold_id": "1503831",
+ "station_id": "1001",
+ "fwis_code": "065WAF434",
+ "fwis_type": "A",
+ "direction": "u",
+ "value": "3.5",
+ "threshold_type": "FW ACTCON FAL"
+ },
+ {
+ "station_threshold_id": "1503832",
+ "station_id": "1001",
+ "fwis_code": "065WAF434",
+ "fwis_type": "A",
+ "direction": "u",
+ "value": "3.88",
+ "threshold_type": "FW ACT FAL"
+ },
+ {
+ "station_threshold_id": "1503833",
+ "station_id": "1001",
+ "fwis_code": "065FWF5402",
+ "fwis_type": "W",
+ "direction": "u",
+ "value": "3.9",
+ "threshold_type": "FW ACTCON FW"
+ },
+ {
+ "station_threshold_id": "1503834",
+ "station_id": "1001",
+ "fwis_code": "065FWF5402",
+ "fwis_type": "W",
+ "direction": "u",
+ "value": "4",
+ "threshold_type": "FW ACTCON FW"
+ },
+ {
+ "station_threshold_id": "1503835",
+ "station_id": "1001",
+ "fwis_code": "065FWF5402",
+ "fwis_type": "W",
+ "direction": "u",
+ "value": "4.2",
+ "threshold_type": "FW ACT FW"
+ },
+ {
+ "station_threshold_id": "1503836",
+ "station_id": "1001",
+ "fwis_code": "065FWF5402",
+ "fwis_type": "W",
+ "direction": "u",
+ "value": "4.3",
+ "threshold_type": "FW ACT FW"
+ }
+ ]
}
diff --git a/test/data/stationRiver.json b/test/data/stationRiver.json
index 8fdc138bb..01c9fd90b 100644
--- a/test/data/stationRiver.json
+++ b/test/data/stationRiver.json
@@ -1,90 +1,145 @@
{
- "station":{
- "rloi_id":1001,
- "station_type":"S",
- "qualifier":"u",
- "telemetry_context_id":"1364571",
- "telemetry_id":"E9140",
- "wiski_id":"253110011",
- "post_process":true,
- "subtract":"0.66",
- "region":"Southern",
- "area":"Solent and South Downs",
- "catchment":"Adur",
- "display_region":"South East",
- "display_area":"Solent and South Downs",
- "display_catchment":"Adur and Ouse",
- "agency_name":"Beeding Bridge",
- "external_name":"Beeding Bridge",
- "location_info":"Upper Beeding",
- "x_coord_actual":519204,
- "y_coord_actual":110626,
- "actual_ngr":"",
- "x_coord_display":519204,
- "y_coord_display":110626,
- "site_max":"4",
- "wiski_river_name":"River Adur",
- "date_open":"1998-01-01T00:00:00.000Z",
- "stage_datum":"0.66",
- "period_of_record":"to date",
- "por_max_value":"3.35",
- "date_por_max":"2013-12-06T01:45:00.000Z",
- "highest_level":"4.007",
- "date_highest_level":"2013-12-06T02:00:00.000Z",
- "por_min_value":"0",
- "date_por_min":"2005-03-21T04:30:00.000Z",
- "percentile_5":"2.84",
- "percentile_95":"0.353",
- "comments":"",
- "status":"Active",
- "status_reason":"",
- "status_date":"2019-01-16T12:22:00.000Z",
- "coordinates":"{\"type\":\"Point\",\"coordinates\":[-0.306835309255374,50.8828385361225]}",
- "geography":"0101000020E6100000CCA1A09030A3D3BFB42568DA00714940",
- "centroid":"0101000020E6100000CCA1A09030A3D3BFB42568DA00714940"
+ "station": {
+ "rloi_id": 1001,
+ "station_type": "S",
+ "qualifier": "u",
+ "telemetry_context_id": "1364571",
+ "telemetry_id": "E9140",
+ "wiski_id": "253110011",
+ "post_process": true,
+ "subtract": "0.66",
+ "region": "Southern",
+ "area": "Solent and South Downs",
+ "catchment": "Adur",
+ "display_region": "South East",
+ "display_area": "Solent and South Downs",
+ "display_catchment": "Adur and Ouse",
+ "agency_name": "Beeding Bridge",
+ "external_name": "Beeding Bridge",
+ "location_info": "Upper Beeding",
+ "x_coord_actual": 519204,
+ "y_coord_actual": 110626,
+ "actual_ngr": "",
+ "x_coord_display": 519204,
+ "y_coord_display": 110626,
+ "site_max": "4",
+ "wiski_river_name": "River Adur",
+ "date_open": "1998-01-01T00:00:00.000Z",
+ "stage_datum": "0.66",
+ "period_of_record": "to date",
+ "por_max_value": "3.35",
+ "date_por_max": "2013-12-06T01:45:00.000Z",
+ "highest_level": "4.007",
+ "date_highest_level": "2013-12-06T02:00:00.000Z",
+ "por_min_value": "0",
+ "date_por_min": "2005-03-21T04:30:00.000Z",
+ "percentile_5": "2.84",
+ "percentile_95": "0.353",
+ "comments": "",
+ "status": "Active",
+ "status_reason": "",
+ "status_date": "2019-01-16T12:22:00.000Z",
+ "coordinates": "{\"type\":\"Point\",\"coordinates\":[-0.306835309255374,50.8828385361225]}",
+ "geography": "0101000020E6100000CCA1A09030A3D3BFB42568DA00714940",
+ "centroid": "0101000020E6100000CCA1A09030A3D3BFB42568DA00714940"
+ },
+ "telemetry": [
+ {
+ "_": 0.805,
+ "err": false,
+ "ts": "2020-07-13T12:00Z"
},
- "telemetry":[
- {
- "_":0.805,
- "err":false,
- "ts":"2020-07-13T12:00Z"
- },
- {
- "_":0.805,
- "err":false,
- "ts":"2020-07-13T11:45Z"
- }
- ],
- "impacts":[],
- "river":{
- "river_id":"river-adur",
- "river_name":"River Adur",
- "navigable":true,
- "view_rank":3,
- "rank":2,
- "rloi_id":1001,
- "up":1006,
- "down":1032,
- "telemetry_id":"E9140",
- "region":"Southern",
- "catchment":"Adur",
- "wiski_river_name":"River Adur",
- "agency_name":"Beeding Bridge",
- "external_name":"Beeding Bridge",
- "station_type":"S",
- "status":"Active",
- "qualifier":"u",
- "iswales":false,
- "value":"0.805",
- "value_timestamp":"2020-07-13T12:00:00.000Z",
- "value_erred":false,
- "trend":"steady",
- "percentile_5":"2.84",
- "percentile_95":"0.353",
- "centroid":"0101000020E6100000CCA1A09030A3D3BFB42568DA00714940",
- "lon":-0.306835309255374,
- "lat":50.8828385361225
- },
- "warningsAlerts":[],
- "imtdThresholds": { "alert": 1.222, "warning": 2.111 }
+ {
+ "_": 0.805,
+ "err": false,
+ "ts": "2020-07-13T11:45Z"
+ }
+ ],
+ "impacts": [],
+ "river": {
+ "river_id": "river-adur",
+ "river_name": "River Adur",
+ "navigable": true,
+ "view_rank": 3,
+ "rank": 2,
+ "rloi_id": 1001,
+ "up": 1006,
+ "down": 1032,
+ "telemetry_id": "E9140",
+ "region": "Southern",
+ "catchment": "Adur",
+ "wiski_river_name": "River Adur",
+ "agency_name": "Beeding Bridge",
+ "external_name": "Beeding Bridge",
+ "station_type": "S",
+ "status": "Active",
+ "qualifier": "u",
+ "iswales": false,
+ "value": "0.805",
+ "value_timestamp": "2020-07-13T12:00:00.000Z",
+ "value_erred": false,
+ "trend": "steady",
+ "percentile_5": "2.84",
+ "percentile_95": "0.353",
+ "centroid": "0101000020E6100000CCA1A09030A3D3BFB42568DA00714940",
+ "lon": -0.306835309255374,
+ "lat": 50.8828385361225
+ },
+ "warningsAlerts": [],
+ "imtdThresholds": [
+ {
+ "station_threshold_id": "1503831",
+ "station_id": "1001",
+ "fwis_code": "065WAF434",
+ "fwis_type": "A",
+ "direction": "u",
+ "value": "3.5",
+ "threshold_type": "FW ACTCON FAL"
+ },
+ {
+ "station_threshold_id": "1503832",
+ "station_id": "1001",
+ "fwis_code": "065WAF434",
+ "fwis_type": "A",
+ "direction": "u",
+ "value": "3.88",
+ "threshold_type": "FW RES FAL"
+ },
+ {
+ "station_threshold_id": "1503833",
+ "station_id": "1001",
+ "fwis_code": "065FWF5402",
+ "fwis_type": "W",
+ "direction": "u",
+ "value": "3.9",
+ "threshold_type": "FW ACTCON FW"
+ },
+ {
+ "station_threshold_id": "1503834",
+ "station_id": "1001",
+ "fwis_code": "065FWF5402",
+ "fwis_type": "W",
+ "direction": "u",
+ "value": "4",
+ "threshold_type": "FW ACTCON FW"
+ },
+ {
+ "station_threshold_id": "1503835",
+ "station_id": "1001",
+ "fwis_code": "065FWF5402",
+ "fwis_type": "W",
+ "direction": "u",
+ "value": "4.2",
+ "threshold_type": "FW ACT FW"
+ },
+ {
+ "station_threshold_id": "1503836",
+ "station_id": "1001",
+ "fwis_code": "065FWF5402",
+ "fwis_type": "W",
+ "direction": "u",
+ "value": "4.3",
+ "threshold_type": "FW RES FW"
+ }
+ ]
}
diff --git a/test/data/stationRiverATCON.json b/test/data/stationRiverATCON.json
new file mode 100644
index 000000000..9b45eda43
--- /dev/null
+++ b/test/data/stationRiverATCON.json
@@ -0,0 +1,109 @@
+{
+ "station": {
+ "rloi_id": 1001,
+ "station_type": "S",
+ "qualifier": "u",
+ "telemetry_context_id": "1364571",
+ "telemetry_id": "E9140",
+ "wiski_id": "253110011",
+ "post_process": true,
+ "subtract": "0.66",
+ "region": "Southern",
+ "area": "Solent and South Downs",
+ "catchment": "Adur",
+ "display_region": "South East",
+ "display_area": "Solent and South Downs",
+ "display_catchment": "Adur and Ouse",
+ "agency_name": "Beeding Bridge",
+ "external_name": "Beeding Bridge",
+ "location_info": "Upper Beeding",
+ "x_coord_actual": 519204,
+ "y_coord_actual": 110626,
+ "actual_ngr": "",
+ "x_coord_display": 519204,
+ "y_coord_display": 110626,
+ "site_max": "4",
+ "wiski_river_name": "River Adur",
+ "date_open": "1998-01-01T00:00:00.000Z",
+ "stage_datum": "0.66",
+ "period_of_record": "to date",
+ "por_max_value": "3.35",
+ "date_por_max": "2013-12-06T01:45:00.000Z",
+ "highest_level": "4.007",
+ "date_highest_level": "2013-12-06T02:00:00.000Z",
+ "por_min_value": "0",
+ "date_por_min": "2005-03-21T04:30:00.000Z",
+ "percentile_5": "2.84",
+ "percentile_95": "0.353",
+ "comments": "",
+ "status": "Active",
+ "status_reason": "",
+ "status_date": "2019-01-16T12:22:00.000Z",
+ "coordinates": "{\"type\":\"Point\",\"coordinates\":[-0.306835309255374,50.8828385361225]}",
+ "geography": "0101000020E6100000CCA1A09030A3D3BFB42568DA00714940",
+ "centroid": "0101000020E6100000CCA1A09030A3D3BFB42568DA00714940"
+ },
+ "telemetry": [
+ {
+ "_": 0.805,
+ "err": false,
+ "ts": "2020-07-13T12:00Z"
+ },
+ {
+ "_": 0.805,
+ "err": false,
+ "ts": "2020-07-13T11:45Z"
+ }
+ ],
+ "impacts": [],
+ "river": {
+ "river_id": "river-adur",
+ "river_name": "River Adur",
+ "navigable": true,
+ "view_rank": 3,
+ "rank": 2,
+ "rloi_id": 1001,
+ "up": 1006,
+ "down": 1032,
+ "telemetry_id": "E9140",
+ "region": "Southern",
+ "catchment": "Adur",
+ "wiski_river_name": "River Adur",
+ "agency_name": "Beeding Bridge",
+ "external_name": "Beeding Bridge",
+ "station_type": "S",
+ "status": "Active",
+ "qualifier": "u",
+ "iswales": false,
+ "value": "0.805",
+ "value_timestamp": "2020-07-13T12:00:00.000Z",
+ "value_erred": false,
+ "trend": "steady",
+ "percentile_5": "2.84",
+ "percentile_95": "0.353",
+ "centroid": "0101000020E6100000CCA1A09030A3D3BFB42568DA00714940",
+ "lon": -0.306835309255374,
+ "lat": 50.8828385361225
+ },
+ "warningsAlerts": [],
+ "imtdThresholds": [
+ {
+ "station_threshold_id": "1503831",
+ "station_id": "1001",
+ "fwis_code": "065WAF434",
+ "fwis_type": "A",
+ "direction": "u",
+ "value": "3.5",
+ "threshold_type": "FW ATCON FAL"
+ },
+ {
+ "station_threshold_id": "1503832",
+ "station_id": "1001",
+ "fwis_code": "065WAF434",
+ "fwis_type": "W",
+ "direction": "u",
+ "value": "3.88",
+ "threshold_type": "FW ATCON FW"
+ }
+ ]
+}
diff --git a/test/models/station.js b/test/models/station.js
index 0164a4cf2..f4028673c 100644
--- a/test/models/station.js
+++ b/test/models/station.js
@@ -34,20 +34,57 @@ lab.experiment('Station model test', () => {
Code.expect(Result.pageTitle).to.equal('River Adur level at Beeding Bridge')
Code.expect(Result.dataOverHourOld).to.equal(true)
Code.expect(Result.postTitle).to.equal('Latest river level information for the River Adur at Beeding Bridge ')
- Code.expect(Result.thresholds[2].values).to.equal([
+ Code.expect(Result.thresholds[0].values).to.equal([
{
id: 'warningThreshold',
- value: '1.45',
description: 'Property flooding is possible above this level. One or more flood warnings may be issued',
- shortname: 'Possible flood warnings'
+ shortname: 'Possible flood warnings',
+ value: '3.64'
+ }
+ ])
+ Code.expect(Result.thresholds[2].values).to.equal([
+ {
+ id: 'alertThreshold',
+ description: 'Low lying land flooding is possible above this level. One or more flood alerts may be issued',
+ shortname: 'Possible flood alerts',
+ value: '3.22'
}
])
Code.expect(Result.thresholds[4].values).to.equal([
+ {
+ id: 'latest',
+ value: '0.81',
+ description: 'Latest level',
+ shortname: ''
+ }
+ ])
+ })
+ lab.test('Test station viewModel river station 1001 only has FW ATCON thresholds', async () => {
+ const stationData = data.stationRiverATCON
+ const viewModel = new ViewModel(stationData)
+
+ const Result = viewModel
+
+ Code.expect(Result.thresholds[1].values).to.equal([
+ {
+ id: 'warningThreshold',
+ description: 'Property flooding is possible above this level. One or more flood warnings may be issued',
+ shortname: 'Possible flood warnings',
+ value: '3.22'
+ }
+ ])
+ Code.expect(Result.thresholds[2].values).to.equal([
{
id: 'alertThreshold',
- value: '0.56',
description: 'Low lying land flooding is possible above this level. One or more flood alerts may be issued',
- shortname: 'Possible flood alerts'
+ shortname: 'Possible flood alerts',
+ value: '2.84'
+ },
+ {
+ description: 'This is the top of the normal range',
+ id: 'pc5',
+ shortname: 'Top of normal range',
+ value: '2.84'
}
])
})
@@ -142,7 +179,7 @@ lab.experiment('Station model test', () => {
const viewModel = new ViewModel(data.stationCoastal)
Code.expect(viewModel.station.plotNegativeValues).to.equal(true)
})
- lab.test('Test station viewModel FFOI station with Impacts', async () => {
+ lab.test('Test station viewModel FFOI station with Impacts ', async () => {
const stationData = data.stationForecastData
const today = moment().format('YYYY-MM-DD')
@@ -183,7 +220,28 @@ lab.experiment('Station model test', () => {
Code.expect(Result.station.id).to.equal(7177)
Code.expect(Result.station.hasImpacts).to.equal(true)
Code.expect(Result.station.formattedPorMaxDate).to.equal('10/02/09')
- Code.expect(Result.thresholds[0].level).to.equal('44.91')
+
+ // Should have FW ACT FAL 3.88 and FW ACT FW 4.20 thresholds as the are no FW RES FAL and FW RES FW in imtdThresholds
+ Code.expect(Result.thresholds[0].values).to.equal(
+ [
+ {
+ description: 'Property flooding is possible above this level. One or more flood warnings may be issued',
+ id: 'warningThreshold',
+ shortname: 'Possible flood warnings',
+ value: '4.20'
+ }
+ ]
+ )
+ Code.expect(Result.thresholds[1].values).to.equal(
+ [
+ {
+ id: 'alertThreshold',
+ description: 'Low lying land flooding is possible above this level. One or more flood alerts may be issued',
+ shortname: 'Possible flood alerts',
+ value: '3.88'
+ }
+ ]
+ )
Code.expect(Result.isUpstream).to.equal(true)
Code.expect(Result.isDownstream).to.equal(false)
Code.expect(Result.severeBanner).to.equal('Severe flood warning for Coast from Fleetwood to Blackpool')
diff --git a/test/routes/station-csv.js b/test/routes/station-csv.js
index ad72d36fd..33087c9b0 100644
--- a/test/routes/station-csv.js
+++ b/test/routes/station-csv.js
@@ -70,6 +70,7 @@ lab.experiment('Routes test - station-csv', () => {
ffoi_station_threshold_id: 133,
ffoi_station_id: 19,
fwis_code: '031WAF213',
+ fwis_type: 'FW ACTCON FAL',
value: 2,
fwa_name: 'River Leadon Catchment',
fwa_type: 'a',
diff --git a/test/routes/station.js b/test/routes/station.js
index 6c33d1fdf..3b722d171 100644
--- a/test/routes/station.js
+++ b/test/routes/station.js
@@ -235,7 +235,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeStationForecastData = () => []
const fakeWarningsAlertsData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getStationTelemetry').callsFake(fakeTelemetryData)
@@ -367,7 +367,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeImpactsData = () => []
const fakeThresholdsData = () => []
const fakeTargetAreasData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getRiverStationByStationId').callsFake(fakeRiverData)
@@ -504,7 +504,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeImpactsData = () => []
const fakeThresholdsData = () => []
const fakeWarningsAlertsData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getRiverStationByStationId').callsFake(fakeRiverData)
@@ -638,7 +638,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeImpactsData = () => []
const fakeThresholdsData = () => []
const fakeWarningsAlertsData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getRiverStationByStationId').callsFake(fakeRiverData)
@@ -737,7 +737,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeThresholdsData = () => []
const fakeWarningsAlertsData = () => []
const fakeRiverStationData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getStationTelemetry').callsFake(fakeTelemetryData)
@@ -870,7 +870,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeImpactsData = () => []
const fakeThresholdsData = () => []
const fakeWarningsAlertsData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getRiverStationByStationId').callsFake(fakeRiverData)
@@ -1006,7 +1006,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeImpactsData = () => []
const fakeThresholdsData = () => []
const fakeWarningsAlertsData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getRiverStationByStationId').callsFake(fakeRiverData)
@@ -1253,7 +1253,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeStationForecastData = () => data.fakeStationForecastData
const fakeWarningsAlertsData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getStationTelemetry').callsFake(fakeTelemetryData)
@@ -1502,7 +1502,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeStationForecastData = () => data.fakeStationForecastDataMax
const fakeWarningsAlertsData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
fakeStationForecastData().SetofValues[0].Value[0].$.date = moment().utc().add(1, 'hours').format('YYYY-MM-DD')
fakeStationForecastData().SetofValues[0].Value[0].$.time = moment().utc().add(1, 'hours').format('HH:mm:ss')
@@ -1642,7 +1642,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeImpactsData = () => []
const fakeThresholdsData = () => []
const fakeTargetAreasData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getRiverStationByStationId').callsFake(fakeRiverData)
@@ -1932,7 +1932,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeImpactsData = () => []
const fakeThresholdsData = () => []
const fakeTargetAreasData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getRiverStationByStationId').callsFake(fakeRiverData)
@@ -1973,136 +1973,6 @@ lab.experiment('Test - /station/{id}', () => {
Code.expect(response.payload).to.contain('Upstream')
Code.expect(response.payload).to.contain('Download data CSV (12KB)')
})
- lab.test('GET station/5146 with Normal river level shows IMTD thresholds if present', async () => {
- const floodService = require('../../server/services/flood')
-
- const fakeStationData = () => {
- return {
- rloi_id: 5146,
- station_type: 'S',
- qualifier: 'u',
- telemetry_context_id: '1146588',
- telemetry_id: '713030',
- wiski_id: '713030',
- post_process: false,
- subtract: null,
- region: 'North West',
- area: 'Cumbria and Lancashire',
- catchment: 'Ribble Douglas and Crossens',
- display_region: 'North West',
- display_area: '',
- display_catchment: '',
- agency_name: 'Walton-Le-Dale',
- external_name: 'Walton-Le-Dale',
- location_info: 'Preston',
- x_coord_actual: 355230,
- y_coord_actual: 428720,
- actual_ngr: '',
- x_coord_display: 355230,
- y_coord_display: 428720,
- site_max: '5',
- wiski_river_name: 'River Ribble',
- date_open: '2001-01-01T00:00:00.000Z',
- stage_datum: '3.642',
- period_of_record: 'to date',
- por_max_value: '5.488',
- date_por_max: '2020-02-09T18:15:00.000Z',
- highest_level: '3.469',
- date_highest_level: '2012-09-26T01:15:00.000Z',
- por_min_value: '-0.07',
- date_por_min: '2009-04-22T12:45:00.000Z',
- percentile_5: '3.5',
- percentile_95: '0.15',
- comments: '',
- status: 'Active',
- status_reason: '',
- status_date: null,
- coordinates: '{"type":"Point","coordinates":[-2.68044442027032,53.7529105624953]}',
- geography: '0101000020E61000001A741ED88C7105C0755D915F5FE04A40',
- centroid: '0101000020E61000001A741ED88C7105C0755D915F5FE04A40'
- }
- }
-
- const fakeRiverData = () => {
- return {
- river_id: 'river-ribble',
- river_name: 'River Ribble',
- navigable: true,
- view_rank: 3,
- rank: 9,
- rloi_id: 5146,
- up: 5122,
- down: null,
- telemetry_id: '713030',
- region: 'North West',
- catchment: 'Ribble Douglas and Crossens',
- wiski_river_name: 'River Ribble',
- agency_name: 'Walton-Le-Dale',
- external_name: 'Walton-Le-Dale',
- station_type: 'S',
- status: 'Active',
- qualifier: 'u',
- iswales: false,
- value: '9.567',
- value_timestamp: '2020-03-17T04:30:00.000Z',
- value_erred: false,
- percentile_5: '3.5',
- percentile_95: '0.15',
- centroid: '0101000020E61000001A741ED88C7105C0755D915F5FE04A40',
- lon: -2.68044442027032,
- lat: 53.7529105624953
- }
- }
-
- const fakeTelemetryData = () => [
- {
- ts: '2020-03-13T01:30Z',
- _: 1.354,
- err: false
- }
- ]
-
- const fakeImpactsData = () => []
- const fakeThresholdsData = () => []
- const fakeTargetAreasData = () => []
- const fakeStationThresholdData = () => { return { alert: 1.11, warning: 2.11 } }
-
- sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
- sandbox.stub(floodService, 'getRiverStationByStationId').callsFake(fakeRiverData)
- sandbox.stub(floodService, 'getStationTelemetry').callsFake(fakeTelemetryData)
- sandbox.stub(floodService, 'getImpactData').callsFake(fakeImpactsData)
- sandbox.stub(floodService, 'getStationForecastThresholds').callsFake(fakeThresholdsData)
- sandbox.stub(floodService, 'getStationImtdThresholds').callsFake(fakeStationThresholdData)
- sandbox.stub(floodService, 'getWarningsAlertsWithinStationBuffer').callsFake(fakeTargetAreasData)
-
- const stationPlugin = {
- plugin: {
- name: 'station',
- register: (server, options) => {
- server.route(require('../../server/routes/station'))
- }
- }
- }
-
- await server.register(require('../../server/plugins/views'))
- await server.register(require('../../server/plugins/session'))
- await server.register(stationPlugin)
- // Add Cache methods to server
- const registerServerMethods = require('../../server/services/server-methods')
- registerServerMethods(server)
-
- await server.initialize()
- const options = {
- method: 'GET',
- url: '/station/5146'
- }
-
- const response = await server.inject(options)
-
- Code.expect(response.statusCode).to.equal(200)
- Code.expect(response.payload).to.contain('Low lying land flooding is possible above this level. One or more flood alerts may be issued')
- Code.expect(response.payload).to.contain('Property flooding is possible above this level. One or more flood warnings may be issued')
- })
lab.test('GET station/5146 with Normal river level does no show IMTD thresholds if not present', async () => {
const floodService = require('../../server/services/flood')
@@ -2326,7 +2196,7 @@ lab.experiment('Test - /station/{id}', () => {
const fakeImpactsData = () => []
const fakeThresholdsData = () => []
const fakeTargetAreasData = () => []
- const fakeStationThresholdData = () => { return { alert: null, warning: null } }
+ const fakeStationThresholdData = () => []
sandbox.stub(floodService, 'getStationById').callsFake(fakeStationData)
sandbox.stub(floodService, 'getRiverStationByStationId').callsFake(fakeRiverData)