canql 4.1.0 → 5.0.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 7fe418e0e14b173d9d9034224dc47c109d3fa6c49ca7d4787cba069aeac13fd5
4
- data.tar.gz: 2bdd3fc53230d07714d58d6b03e4d787fdc564ad42c7278f77877a8ada72a709
3
+ metadata.gz: 99a2f7ebbb5ae3c1cbdd8368b020f8eb7c54d969278db3bdd90277f113095ce9
4
+ data.tar.gz: fb4f6561d61cc9da30dd9a30562c7374a95e52d615b014bc16e5e282529c4975
5
5
  SHA512:
6
- metadata.gz: 2aa9bad734c41ae1a9e40c5eee1685d81d23342def83496141f8b996e599aacc5d2fcd0f73d0678e5372045d47237deb06fca4ed8cd35ca0a6a80b7ebec2d6dc
7
- data.tar.gz: 0e67202d76e7d32fa80c0409a125245fedc898263b35b6c049350480f4ff6197f95cc75cae7970077c0ee7c9569e992647c5e83db7a966f8d3a77bd165fa63b6
6
+ metadata.gz: 93cc26e76a35a5b47600368d7208f81c6cd6457c416f942be852536952d54b9a1bbcb49df7c17f95fb09b5bdaa4581fda91b70e36ad229aae5213914d9d7db39
7
+ data.tar.gz: 2a8bf966e8a0b93411117a09f790f20825c6b27850f1903cea53fd636855d920ec4fdc5dc9bb903b11ec0c2e34275af88ca2e49e4c09b3ea206a6ff2620d626b
@@ -0,0 +1,2 @@
1
+ # Admins should have oversight of the version:
2
+ lib/canql/version.rb @publichealthengland/ndr-admins
@@ -0,0 +1,23 @@
1
+ name: Lint
2
+
3
+ on: [pull_request]
4
+
5
+ jobs:
6
+ rubocop:
7
+ name: RuboCop
8
+
9
+ runs-on: ubuntu-latest
10
+
11
+ steps:
12
+ - uses: actions/checkout@v2
13
+ with:
14
+ fetch-depth: 0 # fetch everything
15
+ - name: Set up Ruby
16
+ uses: ruby/setup-ruby@v1
17
+ with:
18
+ ruby-version: 3.0
19
+ - name: Install dependencies
20
+ run: bundle install
21
+ - name: Run RuboCop against BASE..HEAD changes
22
+ run: bundle exec rake rubocop:diff origin/${GITHUB_BASE_REF#*/}
23
+
@@ -0,0 +1,65 @@
1
+ name: Test
2
+
3
+ on: [push, pull_request]
4
+
5
+ jobs:
6
+ test:
7
+ strategy:
8
+ matrix:
9
+ ruby-version:
10
+ - 2.6
11
+ - 2.7
12
+ - 3.0
13
+
14
+ name: Ruby ${{ matrix.ruby-version }}
15
+
16
+ runs-on: ubuntu-latest
17
+
18
+ steps:
19
+ - uses: actions/checkout@v2
20
+ - name: Set up Ruby
21
+ uses: ruby/setup-ruby@v1
22
+ with:
23
+ ruby-version: ${{ matrix.ruby-version }}
24
+ - name: Install dependencies
25
+ run: bundle install
26
+ - name: Run tests
27
+ run: bundle exec rake
28
+
29
+ # A utility job upon which Branch Protection can depend,
30
+ # thus remaining agnostic of the matrix.
31
+ test_matrix:
32
+ if: ${{ always() }}
33
+ runs-on: ubuntu-latest
34
+ name: Matrix
35
+ needs: test
36
+ steps:
37
+ - name: Check build matrix status
38
+ if: ${{ needs.test.result != 'success' }}
39
+ run: exit 1
40
+
41
+ notify:
42
+ # Run only on master, but regardless of whether tests past:
43
+ if: ${{ always() && github.ref == 'refs/heads/master' }}
44
+
45
+ needs: test_matrix
46
+
47
+ runs-on: ubuntu-latest
48
+
49
+ steps:
50
+ - uses: 8398a7/action-slack@v3
51
+ with:
52
+ status: custom
53
+ fields: workflow,commit,author
54
+ custom_payload: |
55
+ {
56
+ channel: 'C7FQWGDHP',
57
+ username: 'CI – ' + '${{ github.repository }}'.split('/')[1],
58
+ icon_emoji: ':hammer_and_wrench:',
59
+ attachments: [{
60
+ color: '${{ needs.test_matrix.result }}' === 'success' ? 'good' : '${{ needs.test_matrix.result }}' === 'failure' ? 'danger' : 'warning',
61
+ text: `${process.env.AS_WORKFLOW} against \`${{ github.ref }}\` (${process.env.AS_COMMIT}) for ${{ github.actor }} resulted in *${{ needs.test_matrix.result }}*.`
62
+ }]
63
+ }
64
+ env:
65
+ SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
@@ -1,11 +1 @@
1
- inherit_from: 'https://raw.githubusercontent.com/PublicHealthEngland/ndr_dev_support/master/.rubocop.yml'
2
-
3
- Rails:
4
- Enabled: false
5
-
6
- AllCops:
7
- TargetRailsVersion: 4.2
8
- TargetRubyVersion: 2.3
9
-
10
- Style/FrozenStringLiteralComment:
11
- Enabled: true
1
+ require: ndr_dev_support
@@ -1,6 +1,31 @@
1
1
  ## [Unreleased]
2
2
  *no unreleased changes*
3
3
 
4
+ ## 5.0.0 / 2021-01-19
5
+
6
+ ### Changed
7
+ * Changed the values of registry to use registry name rather than codes and added new supra-region options (#54)
8
+
9
+ ### Added
10
+ * Added fetal medicine and dating options to the test group filter (#50)
11
+ * Added new gestation at delivery and booking date to case field existance filter (#52)
12
+
13
+ ## 4.4.1 / 2021-01-13
14
+ ### Fixed
15
+ * Relax constraints to support Rails 6.x
16
+
17
+ ## 4.4.0 / 2020-07-08
18
+ ### Added
19
+ * Added filter for missing and supplied required test result groups (#47)
20
+
21
+ ## 4.3.0 / 2020-06-10
22
+ ### Added
23
+ * Added additional field existance options (#45)
24
+
25
+ ## 4.2.0 / 2020-03-25
26
+ ### Added
27
+ * Added additional EUROCAT category filters for RAG combination
28
+
4
29
  ## 4.1.0 / 2020-03-19
5
30
  ### Added
6
31
  * Added filters for EUROCAT RAG rating (#39)
data/README.md CHANGED
@@ -1,6 +1,6 @@
1
- # CANQL [![Build Status](https://travis-ci.org/PublicHealthEngland/canql.svg?branch=master)](https://travis-ci.org/PublicHealthEngland/canql) [![Gem Version](https://badge.fury.io/rb/canql.svg)](https://rubygems.org/gems/canql)
1
+ # CANQL [![Build Status](https://github.com/publichealthengland/canql/workflows/Test/badge.svg)](https://github.com/publichealthengland/canql/actions?query=workflow%3Atest) [![Gem Version](https://badge.fury.io/rb/canql.svg)](https://rubygems.org/gems/canql)
2
2
 
3
- Congenital Anomaly Natural Query Language (CANQL) is a [Treetop](http://treetop.rubyforge.org/) driven Domain Specific Language (DSL) used by the Public Health England (PHE) National Congenital Anomaly and Rare Disease Registration Service (NCARDRS) to identify cohorts of cases.
3
+ Congenital Anomaly Natural Query Language (CANQL) is a [Treetop](http://treetop.rubyforge.org/)-driven Domain Specific Language (DSL) used by the Public Health England (PHE) National Congenital Anomaly and Rare Disease Registration Service (NCARDRS) to identify cohorts of cases.
4
4
 
5
5
  Used for analysis, research and day-to-day operations to empower non-technical users to write sophisticated human readable queries without the need to know or understand the underlying datastore and/or schema.
6
6
 
@@ -28,7 +28,7 @@ Gem::Specification.new do |spec|
28
28
 
29
29
  spec.add_dependency 'chronic', '~> 0.3'
30
30
  spec.add_dependency 'ndr_support', '>= 3.0', '< 6'
31
- spec.add_dependency 'rails', '>= 4.1', '< 6'
31
+ spec.add_dependency 'rails', '>= 4.1', '< 7'
32
32
  spec.add_dependency 'treetop', '>= 1.4.10'
33
33
 
34
34
  spec.add_development_dependency 'bundler'
@@ -36,7 +36,7 @@ Gem::Specification.new do |spec|
36
36
  spec.add_development_dependency 'guard-minitest'
37
37
  spec.add_development_dependency 'guard-rubocop'
38
38
  spec.add_development_dependency 'minitest'
39
- spec.add_development_dependency 'ndr_dev_support', '~> 5.6'
39
+ spec.add_development_dependency 'ndr_dev_support', '~> 5.9'
40
40
  spec.add_development_dependency 'pry'
41
41
  spec.add_development_dependency 'rake'
42
42
  spec.add_development_dependency 'terminal-notifier-guard' if RUBY_PLATFORM =~ /darwin/
@@ -1,5 +1,17 @@
1
1
  ---
2
2
  file safety:
3
+ ".github/CODEOWNERS":
4
+ comments:
5
+ reviewed_by: josh.pencheon
6
+ safe_revision: a964c47962d47724afd66ba59660589fc3c8b02c
7
+ ".github/workflows/lint.yml":
8
+ comments:
9
+ reviewed_by: josh.pencheon
10
+ safe_revision: 71f6a631758a5a38814d3eafec407e0fde30101f
11
+ ".github/workflows/test.yml":
12
+ comments:
13
+ reviewed_by: josh.pencheon
14
+ safe_revision: 865fc970554fee9207f8e3cd0247133c6a849b24
3
15
  ".gitignore":
4
16
  comments:
5
17
  reviewed_by: timgentry
@@ -9,17 +21,13 @@ file safety:
9
21
  reviewed_by: timgentry
10
22
  safe_revision: 0b34688f1198eace9310f47060aa8915f5b44985
11
23
  ".rubocop.yml":
12
- comments:
13
- reviewed_by: timgentry
14
- safe_revision: 5bc563431f7822e2baf37bbeac9861c36675602d
15
- ".travis.yml":
16
24
  comments:
17
25
  reviewed_by: josh.pencheon
18
- safe_revision: 8adb767031a19aa6b3cea3f1cb05b4a9bcc964f3
26
+ safe_revision: 146b255b240b0efc928d39dd1b70ab221ddc3138
19
27
  CHANGELOG.md:
20
28
  comments:
21
- reviewed_by: timgentry
22
- safe_revision: cef1ddd804f00d7639947464f2f0e5660e9f0fc7
29
+ reviewed_by: josh.pencheon
30
+ safe_revision: f84cb2190f46ee550db796a17455980ab00d3187
23
31
  CODE_OF_CONDUCT.md:
24
32
  comments:
25
33
  reviewed_by: drewthorp
@@ -35,7 +43,7 @@ file safety:
35
43
  README.md:
36
44
  comments:
37
45
  reviewed_by: josh.pencheon
38
- safe_revision: 33feeeaa4b2089e33f563e4c766e91c38b108e36
46
+ safe_revision: 8c07968aa84db92b6f1cc528180f73530ddc6ff5
39
47
  Rakefile:
40
48
  comments:
41
49
  reviewed_by: timgentry
@@ -50,8 +58,8 @@ file safety:
50
58
  safe_revision: 6a666fcabe027056b1c774b2eabb3fdf686911d2
51
59
  canql.gemspec:
52
60
  comments:
53
- reviewed_by: timgentry
54
- safe_revision: 6cb13f43b4353ab7c90ff0406ec13ac169b8e64c
61
+ reviewed_by: josh.pencheon
62
+ safe_revision: 146b255b240b0efc928d39dd1b70ab221ddc3138
55
63
  lib/canql.rb:
56
64
  comments:
57
65
  reviewed_by: timgentry
@@ -63,7 +71,7 @@ file safety:
63
71
  lib/canql/grammars.rb:
64
72
  comments:
65
73
  reviewed_by: josh.pencheon
66
- safe_revision: c431b8a476b84d077e9c39a2a13c2b17a296773d
74
+ safe_revision: c5f8f76b2c335a8554f39a14d6165bf5cd8f9b67
67
75
  lib/canql/grammars/age.treetop:
68
76
  comments: It is a known issue that this is potentially susceptible to certain
69
77
  kinds of DoS attack
@@ -94,13 +102,13 @@ file safety:
94
102
  lib/canql/grammars/main.treetop:
95
103
  comments: It is a known issue that this is potentially susceptible to certain
96
104
  kinds of DoS attack
97
- reviewed_by: timgentry
98
- safe_revision: 05ccd47fcbba92bf5525c4d36118274696169d61
105
+ reviewed_by: josh.pencheon
106
+ safe_revision: 42bb9bd177a761b9d04d728e53fcf0ebd0083ae4
99
107
  lib/canql/grammars/patient.treetop:
100
108
  comments: It is a known issue that this is potentially susceptible to certain
101
109
  kinds of DoS attack
102
- reviewed_by: timgentry
103
- safe_revision: 05ccd47fcbba92bf5525c4d36118274696169d61
110
+ reviewed_by: josh.pencheon
111
+ safe_revision: 7490099869e368dcd5c26ded11eb90229baf4cae
104
112
  lib/canql/grammars/perinatal_hospital.treetop:
105
113
  comments:
106
114
  reviewed_by: josh.pencheon
@@ -113,16 +121,20 @@ file safety:
113
121
  comments: It is a known issue that this is potentially susceptible to certain
114
122
  kinds of DoS attack
115
123
  reviewed_by: josh.pencheon
116
- safe_revision: 4e26ac746098452b01dac88373e401e39f309b74
124
+ safe_revision: 293248a17d087d7557a6aacdcb5bf3fbec946b87
117
125
  lib/canql/grammars/test_result.treetop:
118
126
  comments: It is a known issue that this is potentially susceptible to certain
119
127
  kinds of DoS attack
120
128
  reviewed_by: timgentry
121
129
  safe_revision: c39d24bb500719971969762e94545e82866bf92f
130
+ lib/canql/grammars/test_result_group.treetop:
131
+ comments:
132
+ reviewed_by: josh.pencheon
133
+ safe_revision: 8ea906ca663b98edee2592fc5b0731881573f06b
122
134
  lib/canql/nodes.rb:
123
135
  comments:
124
136
  reviewed_by: josh.pencheon
125
- safe_revision: c431b8a476b84d077e9c39a2a13c2b17a296773d
137
+ safe_revision: c5f8f76b2c335a8554f39a14d6165bf5cd8f9b67
126
138
  lib/canql/nodes/age.rb:
127
139
  comments:
128
140
  reviewed_by: timgentry
@@ -150,11 +162,11 @@ file safety:
150
162
  lib/canql/nodes/main.rb:
151
163
  comments:
152
164
  reviewed_by: josh.pencheon
153
- safe_revision: 511e4238f83eb5b32839c25d94ec2a59145539bb
165
+ safe_revision: c5f8f76b2c335a8554f39a14d6165bf5cd8f9b67
154
166
  lib/canql/nodes/patient.rb:
155
167
  comments:
156
- reviewed_by: timgentry
157
- safe_revision: 05ccd47fcbba92bf5525c4d36118274696169d61
168
+ reviewed_by: josh.pencheon
169
+ safe_revision: 7490099869e368dcd5c26ded11eb90229baf4cae
158
170
  lib/canql/nodes/perinatal_hospital.rb:
159
171
  comments:
160
172
  reviewed_by: josh.pencheon
@@ -167,6 +179,10 @@ file safety:
167
179
  comments:
168
180
  reviewed_by: timgentry
169
181
  safe_revision: c39d24bb500719971969762e94545e82866bf92f
182
+ lib/canql/nodes/test_result_group.rb:
183
+ comments:
184
+ reviewed_by: josh.pencheon
185
+ safe_revision: 42bb9bd177a761b9d04d728e53fcf0ebd0083ae4
170
186
  lib/canql/parser.rb:
171
187
  comments:
172
188
  reviewed_by: timgentry
@@ -177,8 +193,8 @@ file safety:
177
193
  safe_revision: 6932d590299ad4a9d2ba24b425b158c67142bf74
178
194
  lib/canql/version.rb:
179
195
  comments:
180
- reviewed_by: timgentry
181
- safe_revision: cef1ddd804f00d7639947464f2f0e5660e9f0fc7
196
+ reviewed_by: josh.pencheon
197
+ safe_revision: cfe2f76a07880e268e1f29fbac5f6cd380202ce3
182
198
  test/anomaly_test_helper.rb:
183
199
  comments:
184
200
  reviewed_by: josh.pencheon
@@ -201,8 +217,8 @@ file safety:
201
217
  safe_revision: 511e4238f83eb5b32839c25d94ec2a59145539bb
202
218
  test/nodes/case_test.rb:
203
219
  comments:
204
- reviewed_by: timgentry
205
- safe_revision: 05ccd47fcbba92bf5525c4d36118274696169d61
220
+ reviewed_by: josh.pencheon
221
+ safe_revision: 7490099869e368dcd5c26ded11eb90229baf4cae
206
222
  test/nodes/code_test.rb:
207
223
  comments:
208
224
  reviewed_by: josh.pencheon
@@ -210,7 +226,7 @@ file safety:
210
226
  test/nodes/e_base_records_test.rb:
211
227
  comments:
212
228
  reviewed_by: josh.pencheon
213
- safe_revision: 511e4238f83eb5b32839c25d94ec2a59145539bb
229
+ safe_revision: 293248a17d087d7557a6aacdcb5bf3fbec946b87
214
230
  test/nodes/genetic_tests_test.rb:
215
231
  comments:
216
232
  reviewed_by: josh.pencheon
@@ -233,8 +249,8 @@ file safety:
233
249
  safe_revision: 511e4238f83eb5b32839c25d94ec2a59145539bb
234
250
  test/nodes/patient_test.rb:
235
251
  comments:
236
- reviewed_by: timgentry
237
- safe_revision: 05ccd47fcbba92bf5525c4d36118274696169d61
252
+ reviewed_by: josh.pencheon
253
+ safe_revision: 43425805d9ad4a99e63eeb5d50495fa14eaa053b
238
254
  test/nodes/perinatal_hospital_test.rb:
239
255
  comments:
240
256
  reviewed_by: josh.pencheon
@@ -242,16 +258,20 @@ file safety:
242
258
  test/nodes/registry_test.rb:
243
259
  comments:
244
260
  reviewed_by: josh.pencheon
245
- safe_revision: 511e4238f83eb5b32839c25d94ec2a59145539bb
261
+ safe_revision: 293248a17d087d7557a6aacdcb5bf3fbec946b87
262
+ test/nodes/test_result_groups_test.rb:
263
+ comments:
264
+ reviewed_by: josh.pencheon
265
+ safe_revision: 8ea906ca663b98edee2592fc5b0731881573f06b
246
266
  test/nodes/test_results_test.rb:
247
267
  comments:
248
268
  reviewed_by: josh.pencheon
249
269
  safe_revision: 511e4238f83eb5b32839c25d94ec2a59145539bb
250
270
  test/parser_test.rb:
251
271
  comments:
252
- reviewed_by: timgentry
253
- safe_revision: 05ccd47fcbba92bf5525c4d36118274696169d61
272
+ reviewed_by: josh.pencheon
273
+ safe_revision: 293248a17d087d7557a6aacdcb5bf3fbec946b87
254
274
  test/test_helper.rb:
255
275
  comments:
256
276
  reviewed_by: josh.pencheon
257
- safe_revision: 511e4238f83eb5b32839c25d94ec2a59145539bb
277
+ safe_revision: 42bb9bd177a761b9d04d728e53fcf0ebd0083ae4
@@ -9,6 +9,7 @@ Treetop.load File.expand_path('grammars/batch_types', File.dirname(__FILE__))
9
9
  Treetop.load File.expand_path('grammars/e_base_records', File.dirname(__FILE__))
10
10
  Treetop.load File.expand_path('grammars/genetic_test', File.dirname(__FILE__))
11
11
  Treetop.load File.expand_path('grammars/test_result', File.dirname(__FILE__))
12
+ Treetop.load File.expand_path('grammars/test_result_group', File.dirname(__FILE__))
12
13
  Treetop.load File.expand_path('grammars/patient', File.dirname(__FILE__))
13
14
  Treetop.load File.expand_path('grammars/registry', File.dirname(__FILE__))
14
15
  Treetop.load File.expand_path('grammars/provider', File.dirname(__FILE__))
@@ -5,6 +5,7 @@ grammar Canql
5
5
  include Anomaly
6
6
  include GeneticTest
7
7
  include TestResult
8
+ include TestResultGroup
8
9
  include Dates
9
10
  include EBaseRecords
10
11
  include BatchTypes
@@ -127,7 +128,9 @@ grammar Canql
127
128
  end
128
129
 
129
130
  rule case_with_conditions
130
- anomalies / genetic_tests / test_results / perinatal_hospital / case_field_existance / mother_conditions / action_or_ebr
131
+ anomalies / genetic_tests / test_results / perinatal_hospital /
132
+ case_field_existance / test_result_groups / mother_conditions /
133
+ action_or_ebr
131
134
  end
132
135
 
133
136
  rule patient_with_conditions
@@ -13,7 +13,7 @@ module Canql
13
13
  end
14
14
 
15
15
  rule category
16
- space category:('eurocat red' / 'eurocat amber' / 'eurocat green' / 'eurocat') word_break <Nodes::Patient::CategoryNode>
16
+ space category:('eurocat amber and green' / 'eurocat red and amber' / 'eurocat red' / 'eurocat amber' / 'eurocat green' / 'eurocat') word_break <Nodes::Patient::CategoryNode>
17
17
  end
18
18
 
19
19
  rule expected_keyword
@@ -46,16 +46,18 @@ module Canql
46
46
 
47
47
  rule case_field_names
48
48
  patient_field_name:(
49
- 'date of birth' / 'dob' / 'nhs number' / 'delivery postcode' /
50
- 'booking postcode' / 'birth weight' /
49
+ 'date of birth' / 'dob' / 'date of vital status' / 'nhs number' /
50
+ 'delivery postcode' / 'booking postcode' / 'birth weight' /
51
51
  'place of delivery' / 'sex' / 'outcome' / 'edd' /
52
- 'expected delivery date' / 'booking hospital' / 'screening status'
52
+ 'expected delivery date' / 'booking hospital' / 'screening status' /
53
+ 'number of fetuses at delivery' / 'malformed in set' / 'gestation at delivery' /
54
+ 'booking date'
53
55
  )
54
56
  end
55
57
 
56
58
  rule patient_field_names
57
59
  patient_field_name:(
58
- 'date of birth' / 'dob' / 'nhs number' / 'sex'
60
+ 'date of birth' / 'dob' / 'date of vital status' / 'nhs number' / 'sex'
59
61
  )
60
62
  end
61
63
 
@@ -14,14 +14,15 @@ module Canql
14
14
 
15
15
  rule registry_abbr
16
16
  (england / east_mids / thames / east / yorkshire / north_east / north_west /
17
- west_mids / south_west / wessex / london / limbo)
17
+ west_mids / south_west_supra / south_west / wessex / london / limbo /
18
+ northern_supra / midlands_east_supra)
18
19
  end
19
20
 
20
21
  rule thames
21
22
  ('thames valley' / 'thames')
22
23
  {
23
24
  def to_registrycode
24
- '68'
25
+ 'thames'
25
26
  end
26
27
  }
27
28
  end
@@ -30,7 +31,7 @@ module Canql
30
31
  ('east mids' / 'east midlands and south yorkshire' / 'east midlands')
31
32
  {
32
33
  def to_registrycode
33
- '72'
34
+ 'east_mids'
34
35
  end
35
36
  }
36
37
  end
@@ -39,7 +40,7 @@ module Canql
39
40
  'yorkshire'
40
41
  {
41
42
  def to_registrycode
42
- '93'
43
+ 'yorkshire'
43
44
  end
44
45
  }
45
46
  end
@@ -48,7 +49,7 @@ module Canql
48
49
  'north east'
49
50
  {
50
51
  def to_registrycode
51
- '73'
52
+ 'north_east'
52
53
  end
53
54
  }
54
55
  end
@@ -57,7 +58,7 @@ module Canql
57
58
  'north west'
58
59
  {
59
60
  def to_registrycode
60
- '94'
61
+ 'north_west'
61
62
  end
62
63
  }
63
64
  end
@@ -66,7 +67,7 @@ module Canql
66
67
  ('west mids' / 'west midlands')
67
68
  {
68
69
  def to_registrycode
69
- '99'
70
+ 'west_mids'
70
71
  end
71
72
  }
72
73
  end
@@ -75,7 +76,7 @@ module Canql
75
76
  'south west'
76
77
  {
77
78
  def to_registrycode
78
- '84'
79
+ 'south_west'
79
80
  end
80
81
  }
81
82
  end
@@ -84,7 +85,7 @@ module Canql
84
85
  'wessex'
85
86
  {
86
87
  def to_registrycode
87
- '70'
88
+ 'wessex'
88
89
  end
89
90
  }
90
91
  end
@@ -93,7 +94,7 @@ module Canql
93
94
  ('london and south east' / 'london')
94
95
  {
95
96
  def to_registrycode
96
- '95'
97
+ 'london'
97
98
  end
98
99
  }
99
100
  end
@@ -102,7 +103,7 @@ module Canql
102
103
  ('east of england' / 'east')
103
104
  {
104
105
  def to_registrycode
105
- '96'
106
+ 'east'
106
107
  end
107
108
  }
108
109
  end
@@ -111,7 +112,7 @@ module Canql
111
112
  'limbo'
112
113
  {
113
114
  def to_registrycode
114
- '01'
115
+ 'limbo'
115
116
  end
116
117
  }
117
118
  end
@@ -120,7 +121,34 @@ module Canql
120
121
  'england'
121
122
  {
122
123
  def to_registrycode
123
- '00'
124
+ 'england'
125
+ end
126
+ }
127
+ end
128
+
129
+ rule northern_supra
130
+ ('northern supra' / 'northern')
131
+ {
132
+ def to_registrycode
133
+ 'northern_supra'
134
+ end
135
+ }
136
+ end
137
+
138
+ rule midlands_east_supra
139
+ ('midlands & east supra' / 'midlands & east')
140
+ {
141
+ def to_registrycode
142
+ 'midlands_east_supra'
143
+ end
144
+ }
145
+ end
146
+
147
+ rule south_west_supra
148
+ 'south west supra'
149
+ {
150
+ def to_registrycode
151
+ 'south_west_supra'
124
152
  end
125
153
  }
126
154
  end
@@ -0,0 +1,16 @@
1
+ module Canql
2
+ grammar TestResultGroup
3
+ rule test_result_groups
4
+ and_keyword? existance_modifier:test_result_group_existance_keyword group:test_result_group_names <Nodes::TestResultGroup::WithCondition>
5
+ end
6
+
7
+ rule test_result_group_existance_keyword
8
+ # If in furture the reverse is needed use 'supplied require'
9
+ space ('missing required' / 'missing' / 'supplied required' / 'supplied') word_break
10
+ end
11
+
12
+ rule test_result_group_names
13
+ space ('screening' / 'anomaly scan' / 'fetal medicine' / 'dating') word_break
14
+ end
15
+ end
16
+ end
@@ -17,6 +17,7 @@ require 'canql/nodes/batch_types'
17
17
  require 'canql/nodes/anomaly'
18
18
  require 'canql/nodes/genetic_test'
19
19
  require 'canql/nodes/test_result'
20
+ require 'canql/nodes/test_result_group'
20
21
  require 'canql/nodes/patient'
21
22
  require 'canql/nodes/main'
22
23
  require 'canql/nodes/registry'
@@ -32,16 +32,23 @@ module Canql #:nodoc: all
32
32
  anomalies = []
33
33
  genetic_tests = []
34
34
  test_results = []
35
+ test_result_groups = []
35
36
 
36
37
  post.elements.each do |element|
37
38
  anomalies << element.to_anomaly if element.respond_to?(:to_anomaly)
38
39
  genetic_tests << element.to_genetic_test if element.respond_to?(:to_genetic_test)
39
40
  test_results << element.to_test_result if element.respond_to?(:to_test_result)
41
+ if element.respond_to?(:to_test_result_group)
42
+ test_result_groups << element.to_test_result_group
43
+ end
40
44
  end
41
45
 
42
46
  conditions['anomalies'] = { Canql::ALL => anomalies } if anomalies.any?
43
47
  conditions['genetic_tests'] = { Canql::ALL => genetic_tests } if genetic_tests.any?
44
48
  conditions['test_results'] = { Canql::ALL => test_results } if test_results.any?
49
+ if test_result_groups.any?
50
+ conditions['test_result_groups'] = { Canql::ALL => test_result_groups }
51
+ end
45
52
  conditions
46
53
  end
47
54
  end
@@ -30,6 +30,8 @@ module Canql #:nodoc: all
30
30
  return 'eurocat_red' if 'eurocat red' == category.text_value
31
31
  return 'eurocat_amber' if 'eurocat amber' == category.text_value
32
32
  return 'eurocat_green' if 'eurocat green' == category.text_value
33
+ return 'eurocat_amber_green' if 'eurocat amber and green' == category.text_value
34
+ return 'eurocat_red_amber' if 'eurocat red and amber' == category.text_value
33
35
 
34
36
  category.text_value
35
37
  end
@@ -37,19 +39,24 @@ module Canql #:nodoc: all
37
39
 
38
40
  module FieldExists
39
41
  FIELDS = {
40
- 'date of birth': { patient: 'birthdate', mother: 'birthdate' },
41
- 'dob': { patient: 'birthdate', mother: 'birthdate' },
42
- 'delivery postcode': { patient: 'delivery_postcode' },
43
- 'booking postcode': { patient: 'booking_postcode' },
44
- 'nhs number': { patient: 'nhsnumber', mother: 'nhsnumber' },
45
- 'birth weight': { patient: 'weight' },
46
- 'place of delivery': { patient: 'placeofdelivery' },
47
- 'sex': { patient: 'sex' },
48
- 'outcome': { patient: 'outcome' },
49
- 'edd': { patient: 'expecteddeliverydate' },
42
+ 'date of birth': { patient: 'birthdate', mother: 'birthdate' },
43
+ 'dob': { patient: 'birthdate', mother: 'birthdate' },
44
+ 'date of vital status': { patient: 'dateofvitalstatus', mother: 'dateofvitalstatus' },
45
+ 'delivery postcode': { patient: 'delivery_postcode' },
46
+ 'booking postcode': { patient: 'booking_postcode' },
47
+ 'nhs number': { patient: 'nhsnumber', mother: 'nhsnumber' },
48
+ 'birth weight': { patient: 'weight' },
49
+ 'place of delivery': { patient: 'placeofdelivery' },
50
+ 'sex': { patient: 'sex' },
51
+ 'outcome': { patient: 'outcome' },
52
+ 'edd': { patient: 'expecteddeliverydate' },
50
53
  'expected delivery date': { patient: 'expecteddeliverydate' },
51
- 'booking hospital': { patient: 'booking_hospital' },
52
- 'screening status': { patient: 'screeningstatus' }
54
+ 'booking hospital': { patient: 'booking_hospital' },
55
+ 'screening status': { patient: 'screeningstatus' },
56
+ 'number of fetuses at delivery': { patient: 'numoffetusesatdelivery' },
57
+ 'malformed in set': { patient: 'malformedinset' },
58
+ 'gestation at delivery': { patient: 'gestationallength' },
59
+ 'booking date': { patient: 'firstbookingdate' }
53
60
  }.freeze
54
61
 
55
62
  def meta_data_item
@@ -0,0 +1,40 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Canql #:nodoc: all
4
+ module Nodes
5
+ module TestResultGroup
6
+ module WithCondition
7
+ def test_result_group
8
+ group.text_value.strip.parameterize.underscore
9
+ end
10
+
11
+ def to_test_result_group
12
+ test_result_group_hash = { 'exists' => existance_filter }
13
+ test_result_group_hash['required'] = requirement_filter
14
+ test_result_group_hash['group'] = test_result_group_filter if test_result_group.present?
15
+ test_result_group_hash
16
+ end
17
+
18
+ def existance_filter
19
+ {
20
+ Canql::EQUALS => ['supplied required', 'supplied'].include?(
21
+ existance_modifier.text_value.strip
22
+ )
23
+ }
24
+ end
25
+
26
+ def requirement_filter
27
+ {
28
+ Canql::EQUALS => ['supplied required', 'missing required'].include?(
29
+ existance_modifier.text_value.strip
30
+ )
31
+ }
32
+ end
33
+
34
+ def test_result_group_filter
35
+ { Canql::EQUALS => test_result_group }
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
@@ -2,5 +2,5 @@
2
2
 
3
3
  # This stores the current version of the Canql gem
4
4
  module Canql
5
- VERSION = '4.1.0'
5
+ VERSION = '5.0.0'
6
6
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: canql
3
3
  version: !ruby/object:Gem::Version
4
- version: 4.1.0
4
+ version: 5.0.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - PHE NDR Development Team
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2020-03-19 00:00:00.000000000 Z
11
+ date: 2021-01-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: chronic
@@ -53,7 +53,7 @@ dependencies:
53
53
  version: '4.1'
54
54
  - - "<"
55
55
  - !ruby/object:Gem::Version
56
- version: '6'
56
+ version: '7'
57
57
  type: :runtime
58
58
  prerelease: false
59
59
  version_requirements: !ruby/object:Gem::Requirement
@@ -63,7 +63,7 @@ dependencies:
63
63
  version: '4.1'
64
64
  - - "<"
65
65
  - !ruby/object:Gem::Version
66
- version: '6'
66
+ version: '7'
67
67
  - !ruby/object:Gem::Dependency
68
68
  name: treetop
69
69
  requirement: !ruby/object:Gem::Requirement
@@ -154,14 +154,14 @@ dependencies:
154
154
  requirements:
155
155
  - - "~>"
156
156
  - !ruby/object:Gem::Version
157
- version: '5.6'
157
+ version: '5.9'
158
158
  type: :development
159
159
  prerelease: false
160
160
  version_requirements: !ruby/object:Gem::Requirement
161
161
  requirements:
162
162
  - - "~>"
163
163
  - !ruby/object:Gem::Version
164
- version: '5.6'
164
+ version: '5.9'
165
165
  - !ruby/object:Gem::Dependency
166
166
  name: pry
167
167
  requirement: !ruby/object:Gem::Requirement
@@ -210,6 +210,9 @@ executables: []
210
210
  extensions: []
211
211
  extra_rdoc_files: []
212
212
  files:
213
+ - ".github/CODEOWNERS"
214
+ - ".github/workflows/lint.yml"
215
+ - ".github/workflows/test.yml"
213
216
  - ".gitignore"
214
217
  - ".hound.yml"
215
218
  - ".rubocop.yml"
@@ -238,6 +241,7 @@ files:
238
241
  - lib/canql/grammars/provider.treetop
239
242
  - lib/canql/grammars/registry.treetop
240
243
  - lib/canql/grammars/test_result.treetop
244
+ - lib/canql/grammars/test_result_group.treetop
241
245
  - lib/canql/nodes.rb
242
246
  - lib/canql/nodes/age.rb
243
247
  - lib/canql/nodes/anomaly.rb
@@ -250,6 +254,7 @@ files:
250
254
  - lib/canql/nodes/perinatal_hospital.rb
251
255
  - lib/canql/nodes/registry.rb
252
256
  - lib/canql/nodes/test_result.rb
257
+ - lib/canql/nodes/test_result_group.rb
253
258
  - lib/canql/parser.rb
254
259
  - lib/canql/treetop/extensions.rb
255
260
  - lib/canql/version.rb