1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as Vocabulary from './vocabulary';
6 import { pipe } from 'lodash/fp';
8 describe('Vocabulary', () => {
9 let vocabulary: Vocabulary.Vocabulary;
28 {label: "Homo sapiens"}
34 {label: "Canis lupus familiaris"}
40 labels: [{label: "Sizes"}],
43 labels: [{label: "Small"}]
46 labels: [{label: "Medium"}]
49 labels: [{label: "Large"}]
60 it('returns the list of tag keys', () => {
61 const tagKeys = Vocabulary.getTags(vocabulary);
62 // Alphabetically ordered by label
63 expect(tagKeys).toEqual([
64 {id: "IDKEYANIMALS", label: "Animal"},
65 {id: "IDKEYANIMALS", label: "Creature"},
66 {id: "IDKEYCOMMENT", label: "IDKEYCOMMENT"},
67 {id: "IDKEYSIZES", label: "Sizes"},
71 it('returns the tag values for a given key', () => {
72 const tagValues = Vocabulary.getTagValues('IDKEYSIZES', vocabulary);
73 // Alphabetically ordered by label
74 expect(tagValues).toEqual([
75 {id: "IDVALSIZES4", label: "IDVALSIZES4"},
76 {id: "IDVALSIZES3", label: "Large"},
77 {id: "IDVALSIZES2", label: "Medium"},
78 {id: "IDVALSIZES1", label: "Small"},
82 it('returns an empty list of values for an non-existent key', () => {
83 const tagValues = Vocabulary.getTagValues('IDNONSENSE', vocabulary);
84 expect(tagValues).toEqual([]);
87 it('returns a key id for a given key label', () => {
89 // Two labels belonging to the same ID
90 {keyLabel: 'Animal', expected: 'IDKEYANIMALS'},
91 {keyLabel: 'Creature', expected: 'IDKEYANIMALS'},
92 // Non-existent label returns empty string
93 {keyLabel: 'ThisKeyLabelDoesntExist', expected: ''},
95 testCases.forEach(tc => {
96 const tagValueID = Vocabulary.getTagKeyID(tc.keyLabel, vocabulary);
97 expect(tagValueID).toEqual(tc.expected);
101 it('returns an key label for a given key id', () => {
103 // ID with many labels return the first one
104 {keyID: 'IDKEYANIMALS', expected: 'Animal'},
105 // Key IDs without any labels or unknown keys should return the literal
106 // key from the API's response (that is, the key 'id')
107 {keyID: 'IDKEYCOMMENT', expected: 'IDKEYCOMMENT'},
108 {keyID: 'FOO', expected: 'FOO'},
110 testCases.forEach(tc => {
111 const tagValueID = Vocabulary.getTagKeyLabel(tc.keyID, vocabulary);
112 expect(tagValueID).toEqual(tc.expected);
116 it('returns a value id for a given key id and value label', () => {
118 // Key ID and value label known
119 {keyID: 'IDKEYANIMALS', valueLabel: 'Human', expected: 'IDVALANIMALS1'},
120 {keyID: 'IDKEYANIMALS', valueLabel: 'Homo sapiens', expected: 'IDVALANIMALS1'},
121 // Key ID known, value label unknown
122 {keyID: 'IDKEYANIMALS', valueLabel: 'Dinosaur', expected: ''},
124 {keyID: 'IDNONSENSE', valueLabel: 'Does not matter', expected: ''},
126 testCases.forEach(tc => {
127 const tagValueID = Vocabulary.getTagValueID(tc.keyID, tc.valueLabel, vocabulary);
128 expect(tagValueID).toEqual(tc.expected);
132 it('returns a value label for a given key & value id pair', () => {
134 // Known key & value ids with multiple value labels: returns the first label
135 {keyId: 'IDKEYANIMALS', valueId: 'IDVALANIMALS1', expected: 'Human'},
136 // Values without label or unknown values should return the literal value from
137 // the API's response (that is, the value 'id')
138 {keyId: 'IDKEYSIZES', valueId: 'IDVALSIZES4', expected: 'IDVALSIZES4'},
139 {keyId: 'IDKEYCOMMENT', valueId: 'FOO', expected: 'FOO'},
140 {keyId: 'IDKEYANIMALS', valueId: 'BAR', expected: 'BAR'},
141 {keyId: 'IDKEYNONSENSE', valueId: 'FOOBAR', expected: 'FOOBAR'},
143 testCases.forEach(tc => {
144 const tagValueLabel = Vocabulary.getTagValueLabel(tc.keyId, tc.valueId, vocabulary);
145 expect(tagValueLabel).toEqual(tc.expected);