Harden yang-model-util test suite
[yangtools.git] / yang / yang-model-util / src / test / java / org / opendaylight / yangtools / yang / model / util / type / TypeTest.java
1 /*
2  * Copyright (c) 2016 Cisco Systems, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8
9 package org.opendaylight.yangtools.yang.model.util.type;
10
11 import static org.junit.Assert.assertEquals;
12 import static org.junit.Assert.assertFalse;
13 import static org.junit.Assert.assertNotNull;
14 import static org.junit.Assert.assertSame;
15 import static org.junit.Assert.assertTrue;
16 import static org.mockito.Mockito.doReturn;
17 import static org.mockito.Mockito.mock;
18
19 import com.google.common.collect.ImmutableList;
20 import com.google.common.collect.ImmutableRangeSet;
21 import com.google.common.collect.Range;
22 import com.google.common.collect.RangeSet;
23 import java.util.List;
24 import java.util.Optional;
25 import org.junit.Test;
26 import org.opendaylight.yangtools.concepts.Builder;
27 import org.opendaylight.yangtools.yang.common.QName;
28 import org.opendaylight.yangtools.yang.model.api.ConstraintMetaDefinition;
29 import org.opendaylight.yangtools.yang.model.api.IdentitySchemaNode;
30 import org.opendaylight.yangtools.yang.model.api.RevisionAwareXPath;
31 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
32 import org.opendaylight.yangtools.yang.model.api.Status;
33 import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
34 import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
35 import org.opendaylight.yangtools.yang.model.api.stmt.UnresolvedNumber;
36 import org.opendaylight.yangtools.yang.model.api.stmt.ValueRange;
37 import org.opendaylight.yangtools.yang.model.api.type.BinaryTypeDefinition;
38 import org.opendaylight.yangtools.yang.model.api.type.BitsTypeDefinition;
39 import org.opendaylight.yangtools.yang.model.api.type.BitsTypeDefinition.Bit;
40 import org.opendaylight.yangtools.yang.model.api.type.EnumTypeDefinition.EnumPair;
41 import org.opendaylight.yangtools.yang.model.api.type.IdentityrefTypeDefinition;
42 import org.opendaylight.yangtools.yang.model.api.type.InstanceIdentifierTypeDefinition;
43 import org.opendaylight.yangtools.yang.model.api.type.Int16TypeDefinition;
44 import org.opendaylight.yangtools.yang.model.api.type.Int32TypeDefinition;
45 import org.opendaylight.yangtools.yang.model.api.type.Int64TypeDefinition;
46 import org.opendaylight.yangtools.yang.model.api.type.Int8TypeDefinition;
47 import org.opendaylight.yangtools.yang.model.api.type.PatternConstraint;
48 import org.opendaylight.yangtools.yang.model.api.type.StringTypeDefinition;
49 import org.opendaylight.yangtools.yang.model.api.type.Uint16TypeDefinition;
50 import org.opendaylight.yangtools.yang.model.api.type.Uint32TypeDefinition;
51 import org.opendaylight.yangtools.yang.model.api.type.Uint64TypeDefinition;
52 import org.opendaylight.yangtools.yang.model.api.type.Uint8TypeDefinition;
53 import org.opendaylight.yangtools.yang.model.util.BaseConstraints;
54 import org.opendaylight.yangtools.yang.model.util.RevisionAwareXPathImpl;
55
56 public class TypeTest {
57     private static final QName Q_NAME = QName.create("test.namespace", "2016-01-01", "test-name");
58     private static final SchemaPath SCHEMA_PATH = SchemaPath.create(true, Q_NAME);
59     private static final RevisionAwareXPath REVISION_AWARE_XPATH = new RevisionAwareXPathImpl("/test", true);
60     private static final Bit BIT_A = BitBuilder.create(SCHEMA_PATH, 55L).setDescription("description")
61             .setReference("reference").build();
62     private static final Optional<String> ABSENT = Optional.empty();
63
64     @Test
65     public void binaryTypeTest() {
66         final BaseBinaryType baseBinaryType1 = BaseBinaryType.INSTANCE;
67         final BaseBinaryType baseBinaryType2 = (BaseBinaryType)BaseTypes.binaryType();
68         hashCodeEqualsToStringTest(baseBinaryType1, baseBinaryType2);
69         assertEquals(baseBinaryType1.getLengthConstraint(), baseBinaryType2.getLengthConstraint());
70
71         final DerivedBinaryType derivedBinaryType1 = (DerivedBinaryType)DerivedTypes.derivedTypeBuilder(baseBinaryType1,
72                 SCHEMA_PATH).build();
73         final DerivedBinaryType derivedBinaryType2 = (DerivedBinaryType)DerivedTypes.derivedTypeBuilder(baseBinaryType2,
74                 SCHEMA_PATH).build();
75         hashCodeEqualsToStringTest(derivedBinaryType1, derivedBinaryType2);
76
77         final RestrictedBinaryType restrictedBinaryType1 = (RestrictedBinaryType)RestrictedTypes.newBinaryBuilder(
78                 baseBinaryType1, SCHEMA_PATH).buildType();
79         final RestrictedBinaryType restrictedBinaryType2 = (RestrictedBinaryType)RestrictedTypes.newBinaryBuilder(
80                 baseBinaryType2, SCHEMA_PATH).buildType();
81         hashCodeEqualsToStringTest(restrictedBinaryType1, restrictedBinaryType2);
82
83         final LengthRestrictedTypeBuilder<BinaryTypeDefinition> lengthRestrictedTypeBuilder = RestrictedTypes
84                 .newBinaryBuilder(baseBinaryType1, SCHEMA_PATH);
85         final BaseBinaryType baseBinaryType = (BaseBinaryType)lengthRestrictedTypeBuilder.build();
86         assertEquals(baseBinaryType, baseBinaryType1);
87         concreteBuilderTest(baseBinaryType1, derivedBinaryType1);
88     }
89
90     @Test
91     public void booleanTypeTest() {
92         final BaseBooleanType baseBooleanType1 = BaseBooleanType.INSTANCE;
93         final BaseBooleanType baseBooleanType2 = (BaseBooleanType)BaseTypes.booleanType();
94         hashCodeEqualsToStringTest(baseBooleanType1, baseBooleanType2);
95
96         final DerivedBooleanType derivedBooleanType1 = (DerivedBooleanType)DerivedTypes.derivedTypeBuilder(
97                 baseBooleanType1, SCHEMA_PATH).build();
98         final DerivedBooleanType derivedBooleanType2 = (DerivedBooleanType)DerivedTypes.derivedTypeBuilder(
99                 baseBooleanType1, SCHEMA_PATH).build();
100         hashCodeEqualsToStringTest(derivedBooleanType1, derivedBooleanType2);
101
102         restrictedBuilderTest(RestrictedTypes.newBooleanBuilder(baseBooleanType1, SCHEMA_PATH), RestrictedTypes
103                 .newBooleanBuilder(baseBooleanType2, SCHEMA_PATH));
104         concreteBuilderTest(baseBooleanType1, derivedBooleanType1);
105     }
106
107     @Test
108     public void identityrefTypeTest() {
109         final IdentityrefTypeBuilder identityrefTypeBuilder1 = BaseTypes.identityrefTypeBuilder(SCHEMA_PATH);
110         final IdentitySchemaNode identitySchemaNode = mock(IdentitySchemaNode.class);
111         doReturn("identitySchemaNode").when(identitySchemaNode).toString();
112         identityrefTypeBuilder1.addIdentity(identitySchemaNode);
113         final IdentityrefTypeDefinition identityrefTypeDefinition1 = identityrefTypeBuilder1.build();
114         final IdentityrefTypeBuilder identityrefTypeBuilder2 = BaseTypes.identityrefTypeBuilder(SCHEMA_PATH);
115         identityrefTypeBuilder2.addIdentity(identitySchemaNode);
116         final IdentityrefTypeDefinition identityrefTypeDefinition2 = identityrefTypeBuilder2.build();
117         hashCodeEqualsToStringTest(identityrefTypeDefinition1, identityrefTypeDefinition2);
118
119         final DerivedIdentityrefType derivedIdentityrefType1 = (DerivedIdentityrefType)DerivedTypes.derivedTypeBuilder(
120                 identityrefTypeDefinition1, SCHEMA_PATH).build();
121         final DerivedIdentityrefType derivedIdentityrefType2 = (DerivedIdentityrefType)DerivedTypes.derivedTypeBuilder(
122                 identityrefTypeDefinition2, SCHEMA_PATH).build();
123         hashCodeEqualsToStringTest(derivedIdentityrefType1, derivedIdentityrefType2);
124         concreteBuilderTest(identityrefTypeDefinition1, derivedIdentityrefType1);
125
126         restrictedBuilderTest(RestrictedTypes.newIdentityrefBuilder(derivedIdentityrefType1, SCHEMA_PATH),
127                 RestrictedTypes.newIdentityrefBuilder(derivedIdentityrefType2, SCHEMA_PATH));
128     }
129
130     @Test
131     public void decimalTypeTest() {
132         final BaseDecimalType baseDecimalType1 = (BaseDecimalType)BaseTypes.decimalTypeBuilder(SCHEMA_PATH)
133                 .setFractionDigits(1)
134                 .buildType();
135         final BaseDecimalType baseDecimalType2 = (BaseDecimalType)BaseTypes.decimalTypeBuilder(SCHEMA_PATH)
136                 .setFractionDigits(1)
137                 .buildType();
138         hashCodeEqualsToStringTest(baseDecimalType1, baseDecimalType2);
139         assertEquals(baseDecimalType1.getFractionDigits(), baseDecimalType2.getFractionDigits());
140
141         final DerivedDecimalType derivedDecimalType1 = (DerivedDecimalType)DerivedTypes
142                 .derivedTypeBuilder(baseDecimalType1, SCHEMA_PATH).build();
143         final DerivedDecimalType derivedDecimalType2 = (DerivedDecimalType)DerivedTypes
144                 .derivedTypeBuilder(baseDecimalType1, SCHEMA_PATH).build();
145         hashCodeEqualsToStringTest(derivedDecimalType1, derivedDecimalType2);
146
147         final RestrictedDecimalType restrictedDecimalType1 = (RestrictedDecimalType)
148                 RestrictedTypes.newDecima64Builder(baseDecimalType1, SCHEMA_PATH).buildType();
149         final RestrictedDecimalType restrictedDecimalType2 = (RestrictedDecimalType)
150                 RestrictedTypes.newDecima64Builder(baseDecimalType2, SCHEMA_PATH).buildType();
151         hashCodeEqualsToStringTest(restrictedDecimalType1, restrictedDecimalType2);
152         concreteBuilderTest(baseDecimalType1, derivedDecimalType1);
153     }
154
155     @Test
156     public void emptyTypeTest() {
157         final BaseEmptyType baseEmptyType1 = BaseEmptyType.INSTANCE;
158         final BaseEmptyType baseEmptyType2 = (BaseEmptyType)BaseTypes.emptyType();
159         hashCodeEqualsToStringTest(baseEmptyType1, baseEmptyType2);
160
161         final DerivedEmptyType derivedEmptyType1 = (DerivedEmptyType)DerivedTypes.derivedTypeBuilder(
162                 baseEmptyType1, SCHEMA_PATH).build();
163         final DerivedEmptyType derivedEmptyType2 = (DerivedEmptyType)DerivedTypes.derivedTypeBuilder(
164                 baseEmptyType2, SCHEMA_PATH).build();
165         hashCodeEqualsToStringTest(derivedEmptyType1, derivedEmptyType2);
166
167         restrictedBuilderTest(RestrictedTypes.newEmptyBuilder(baseEmptyType1, SCHEMA_PATH),
168                 RestrictedTypes.newEmptyBuilder(baseEmptyType2, SCHEMA_PATH));
169         concreteBuilderTest(baseEmptyType1, derivedEmptyType1);
170     }
171
172     @Test
173     public void instanceIdentifierTypeTest() {
174         final BaseInstanceIdentifierType baseInstanceIdentifierType1 = BaseInstanceIdentifierType.INSTANCE;
175         final BaseInstanceIdentifierType baseInstanceIdentifierType2 = (BaseInstanceIdentifierType)BaseTypes
176                 .instanceIdentifierType();
177         hashCodeEqualsToStringTest(baseInstanceIdentifierType1, baseInstanceIdentifierType2);
178         assertFalse(baseInstanceIdentifierType1.requireInstance());
179
180         final DerivedInstanceIdentifierType derivedInstanceIdentifierType1 = (DerivedInstanceIdentifierType)
181                 DerivedTypes.derivedTypeBuilder(baseInstanceIdentifierType1, SCHEMA_PATH).build();
182         final DerivedInstanceIdentifierType derivedInstanceIdentifierType2 = (DerivedInstanceIdentifierType)
183                 DerivedTypes.derivedTypeBuilder(baseInstanceIdentifierType2, SCHEMA_PATH).build();
184         hashCodeEqualsToStringTest(derivedInstanceIdentifierType1, derivedInstanceIdentifierType2);
185
186         final InstanceIdentifierTypeBuilder instanceIdentifierBuilder1 = RestrictedTypes
187                 .newInstanceIdentifierBuilder(baseInstanceIdentifierType1, SCHEMA_PATH);
188         instanceIdentifierBuilder1.setRequireInstance(true);
189         final InstanceIdentifierTypeDefinition instanceIdentifierTypeDefinition1 = instanceIdentifierBuilder1
190                 .buildType();
191         final InstanceIdentifierTypeBuilder instanceIdentifierBuilder2 = RestrictedTypes
192                 .newInstanceIdentifierBuilder(baseInstanceIdentifierType1, SCHEMA_PATH);
193         instanceIdentifierBuilder2.setRequireInstance(true);
194         final InstanceIdentifierTypeDefinition instanceIdentifierTypeDefinition2 = instanceIdentifierBuilder2
195                 .buildType();
196         hashCodeEqualsToStringTest(instanceIdentifierTypeDefinition2, instanceIdentifierTypeDefinition1);
197         concreteBuilderTest(baseInstanceIdentifierType1, derivedInstanceIdentifierType1);
198     }
199
200     @Test
201     public void integerTypeTest() {
202         final Int8TypeDefinition integerTypeDefinition8 = BaseTypes.int8Type();
203         final Int16TypeDefinition integerTypeDefinition16 = BaseTypes.int16Type();
204         final Int32TypeDefinition integerTypeDefinition32 = BaseTypes.int32Type();
205         final Int64TypeDefinition integerTypeDefinition64 = BaseTypes.int64Type();
206         assertTrue(BaseTypes.isInt8(integerTypeDefinition8));
207         assertTrue(BaseTypes.isInt16(integerTypeDefinition16));
208         assertTrue(BaseTypes.isInt32(integerTypeDefinition32));
209         assertTrue(BaseTypes.isInt64(integerTypeDefinition64));
210         testInstance(BaseInt8Type.INSTANCE, integerTypeDefinition8);
211         testInstance(BaseInt16Type.INSTANCE, integerTypeDefinition16);
212         testInstance(BaseInt32Type.INSTANCE, integerTypeDefinition32);
213         testInstance(BaseInt64Type.INSTANCE, integerTypeDefinition64);
214
215         final RestrictedInt8Type restrictedIntegerType1 = (RestrictedInt8Type)RestrictedTypes.newInt8Builder(
216                 integerTypeDefinition8, SCHEMA_PATH).buildType();
217         final RestrictedInt8Type restrictedIntegerType2 = (RestrictedInt8Type)RestrictedTypes.newInt8Builder(
218                 BaseInt8Type.INSTANCE, SCHEMA_PATH).buildType();
219         hashCodeEqualsToStringTest(restrictedIntegerType1, restrictedIntegerType2);
220
221         final Uint8TypeDefinition integerTypeDefinitionu8 = BaseTypes.uint8Type();
222         final Uint16TypeDefinition integerTypeDefinitionu16 = BaseTypes.uint16Type();
223         final Uint32TypeDefinition integerTypeDefinitionu32 = BaseTypes.uint32Type();
224         final Uint64TypeDefinition integerTypeDefinitionu64 = BaseTypes.uint64Type();
225         assertTrue(BaseTypes.isUint8(integerTypeDefinitionu8));
226         assertTrue(BaseTypes.isUint16(integerTypeDefinitionu16));
227         assertTrue(BaseTypes.isUint32(integerTypeDefinitionu32));
228         assertTrue(BaseTypes.isUint64(integerTypeDefinitionu64));
229         testInstance(BaseUint8Type.INSTANCE, integerTypeDefinitionu8);
230         testInstance(BaseUint16Type.INSTANCE, integerTypeDefinitionu16);
231         testInstance(BaseUint32Type.INSTANCE, integerTypeDefinitionu32);
232         testInstance(BaseUint64Type.INSTANCE, BaseTypes.baseTypeOf(integerTypeDefinitionu64));
233
234         final DerivedInt8Type derivedIntegerType1 = (DerivedInt8Type)DerivedTypes
235                 .derivedTypeBuilder(integerTypeDefinition8, SCHEMA_PATH).build();
236         final DerivedInt8Type derivedIntegerType2 = (DerivedInt8Type)DerivedTypes
237                 .derivedTypeBuilder(BaseInt8Type.INSTANCE, SCHEMA_PATH).build();
238         hashCodeEqualsToStringTest(derivedIntegerType1, derivedIntegerType2);
239
240         final DerivedUint8Type derivedUnsignedType1 = (DerivedUint8Type)DerivedTypes
241                 .derivedTypeBuilder(integerTypeDefinitionu8, SCHEMA_PATH).build();
242         final DerivedUint8Type derivedUnsignedType2 = (DerivedUint8Type)DerivedTypes
243                 .derivedTypeBuilder(BaseUint8Type.INSTANCE, SCHEMA_PATH).build();
244         hashCodeEqualsToStringTest(derivedUnsignedType1, derivedUnsignedType2);
245
246         final RestrictedUint8Type restrictedUnsignedType1 = (RestrictedUint8Type)RestrictedTypes
247                 .newUint8Builder(integerTypeDefinitionu8, SCHEMA_PATH).buildType();
248         final RestrictedUint8Type restrictedUnsignedType2 = (RestrictedUint8Type)RestrictedTypes
249                 .newUint8Builder(BaseUint8Type.INSTANCE, SCHEMA_PATH).buildType();
250         hashCodeEqualsToStringTest(restrictedUnsignedType1, restrictedUnsignedType2);
251         concreteBuilderTest(integerTypeDefinition8, derivedIntegerType1);
252         concreteBuilderTest(integerTypeDefinitionu8, derivedUnsignedType2);
253
254         final DerivedTypeBuilder<?> derivedTypeBuilder = DerivedTypes.derivedTypeBuilder(integerTypeDefinition8,
255                 SCHEMA_PATH);
256         derivedTypeBuilder.setDefaultValue(1);
257         derivedTypeBuilder.setDescription("test-description");
258         derivedTypeBuilder.setReference("test-reference");
259         derivedTypeBuilder.setUnits("Int");
260         derivedTypeBuilder.setStatus(Status.CURRENT);
261         assertEquals(derivedTypeBuilder.getStatus(), Status.CURRENT);
262         assertEquals(derivedTypeBuilder.getDescription(), "test-description");
263         assertEquals(derivedTypeBuilder.getReference(), "test-reference");
264         assertEquals(derivedTypeBuilder.getUnits(), "Int");
265     }
266
267     @Test
268     public void stringTypeTest() {
269         final BaseStringType baseStringType1 = BaseStringType.INSTANCE;
270         final BaseStringType baseStringType2 = (BaseStringType)BaseTypes.stringType();
271         hashCodeEqualsToStringTest(baseStringType1, baseStringType2);
272         assertEquals(baseStringType1.getLengthConstraint(), baseStringType2.getLengthConstraint());
273         assertEquals(baseStringType1.getPatternConstraints(), baseStringType2.getPatternConstraints());
274
275         final DerivedStringType derivedStringType1 = (DerivedStringType)
276                 DerivedTypes.derivedTypeBuilder(baseStringType1, SCHEMA_PATH).build();
277         final DerivedStringType derivedStringType2 = (DerivedStringType)
278                 DerivedTypes.derivedTypeBuilder(baseStringType2, SCHEMA_PATH).build();
279         hashCodeEqualsToStringTest(derivedStringType1, derivedStringType2);
280
281         final RestrictedStringType restrictedStringType1 = (RestrictedStringType)RestrictedTypes
282                 .newStringBuilder(baseStringType1, SCHEMA_PATH).buildType();
283         final RestrictedStringType restrictedStringType2 = (RestrictedStringType)RestrictedTypes
284                 .newStringBuilder(baseStringType2, SCHEMA_PATH).buildType();
285         hashCodeEqualsToStringTest(restrictedStringType1, restrictedStringType2);
286         concreteBuilderTest(baseStringType1, derivedStringType1);
287
288         final StringTypeBuilder stringTypeBuilder = new StringTypeBuilder(baseStringType1, SCHEMA_PATH);
289         final PatternConstraint patternConstraint = BaseConstraints.newPatternConstraint("pattern", ABSENT, ABSENT);
290         stringTypeBuilder.addPatternConstraint(patternConstraint);
291         final StringTypeDefinition stringTypeDefinition = stringTypeBuilder.buildType();
292         assertNotNull(stringTypeDefinition);
293     }
294
295     @Test
296     public void bitsTypeTest() {
297         final BitsTypeBuilder bitsTypeBuilder = BaseTypes.bitsTypeBuilder(SCHEMA_PATH);
298         bitsTypeBuilder.addBit(BIT_A);
299         final BitsTypeDefinition bitsTypeDefinition1 = bitsTypeBuilder.build();
300         final BitsTypeDefinition bitsTypeDefinition2 = bitsTypeBuilder.build();
301         hashCodeEqualsToStringTest(bitsTypeDefinition1, bitsTypeDefinition2);
302         assertEquals(bitsTypeDefinition1.getBits(), bitsTypeDefinition1.getBits());
303
304         final DerivedBitsType derivedBitsType1 = (DerivedBitsType)DerivedTypes
305                 .derivedTypeBuilder(bitsTypeDefinition1, SCHEMA_PATH).build();
306         final DerivedBitsType derivedBitsType2 = (DerivedBitsType)DerivedTypes
307                 .derivedTypeBuilder(bitsTypeDefinition2, SCHEMA_PATH).build();
308         hashCodeEqualsToStringTest(derivedBitsType1, derivedBitsType2);
309
310         restrictedBuilderTest(RestrictedTypes.newBitsBuilder(bitsTypeDefinition1, SCHEMA_PATH),
311                 RestrictedTypes.newBitsBuilder(bitsTypeDefinition2, SCHEMA_PATH));
312         concreteBuilderTest(bitsTypeDefinition1, derivedBitsType1);
313     }
314
315     @Test
316     public void enumerationTypeTest() {
317         final BaseEnumerationType baseEnumerationType1 = (BaseEnumerationType)BaseTypes.enumerationTypeBuilder(
318                 SCHEMA_PATH).build();
319         final BaseEnumerationType baseEnumerationType2 = (BaseEnumerationType)BaseTypes.enumerationTypeBuilder(
320                 SCHEMA_PATH).build();
321         hashCodeEqualsToStringTest(baseEnumerationType1, baseEnumerationType2);
322         assertEquals(baseEnumerationType1.getValues(), baseEnumerationType2.getValues());
323
324         final DerivedEnumerationType derivedEnumerationType1 = (DerivedEnumerationType)DerivedTypes
325                 .derivedTypeBuilder(baseEnumerationType1, SCHEMA_PATH).build();
326         final DerivedEnumerationType derivedEnumerationType2 = (DerivedEnumerationType)DerivedTypes
327                 .derivedTypeBuilder(baseEnumerationType2, SCHEMA_PATH).build();
328         hashCodeEqualsToStringTest(derivedEnumerationType1, derivedEnumerationType2);
329
330         restrictedBuilderTest(RestrictedTypes.newEnumerationBuilder(baseEnumerationType1, SCHEMA_PATH),
331                 RestrictedTypes.newEnumerationBuilder(baseEnumerationType2, SCHEMA_PATH));
332         concreteBuilderTest(baseEnumerationType1, derivedEnumerationType1);
333     }
334
335     @Test
336     public void leafrefTypeTest() {
337         final LeafrefTypeBuilder leafrefTypeBuilder1 = BaseTypes.leafrefTypeBuilder(SCHEMA_PATH);
338         final LeafrefTypeBuilder leafrefTypeBuilder2 = BaseTypes.leafrefTypeBuilder(SCHEMA_PATH);
339         leafrefTypeBuilder1.setPathStatement(REVISION_AWARE_XPATH);
340         leafrefTypeBuilder2.setPathStatement(REVISION_AWARE_XPATH);
341         final BaseLeafrefType baseLeafrefType1 = (BaseLeafrefType)leafrefTypeBuilder1.build();
342         final BaseLeafrefType baseLeafrefType2 = (BaseLeafrefType)leafrefTypeBuilder1.build();
343         hashCodeEqualsToStringTest(baseLeafrefType1, baseLeafrefType2);
344         assertEquals(baseLeafrefType1.getPathStatement(), REVISION_AWARE_XPATH);
345
346         final DerivedLeafrefType derivedLeafrefType1 = (DerivedLeafrefType)DerivedTypes
347                 .derivedTypeBuilder(baseLeafrefType1, SCHEMA_PATH).build();
348         final DerivedLeafrefType derivedLeafrefType2 = (DerivedLeafrefType)DerivedTypes
349                 .derivedTypeBuilder(baseLeafrefType2, SCHEMA_PATH).build();
350         hashCodeEqualsToStringTest(derivedLeafrefType1, derivedLeafrefType2);
351
352         restrictedBuilderTest(RestrictedTypes.newLeafrefBuilder(baseLeafrefType1, SCHEMA_PATH),
353                 RestrictedTypes.newLeafrefBuilder(baseLeafrefType2, SCHEMA_PATH));
354         concreteBuilderTest(baseLeafrefType1, derivedLeafrefType1);
355     }
356
357     @Test
358     public void unionTypeTest() throws IllegalAccessException, InstantiationException {
359         final BaseDecimalType baseDecimalType1 = (BaseDecimalType)BaseTypes.decimalTypeBuilder(SCHEMA_PATH)
360                 .setFractionDigits(1)
361                 .buildType();
362         final BaseDecimalType baseDecimalType2 = (BaseDecimalType)BaseTypes.decimalTypeBuilder(SCHEMA_PATH)
363                 .setFractionDigits(1)
364                 .buildType();
365         final UnionTypeBuilder unionTypeBuilder1 = BaseTypes.unionTypeBuilder(SCHEMA_PATH);
366         final UnionTypeBuilder unionTypeBuilder2 = BaseTypes.unionTypeBuilder(SCHEMA_PATH);
367         unionTypeBuilder1.addType(baseDecimalType1);
368         unionTypeBuilder2.addType(baseDecimalType2);
369         final BaseUnionType baseUnionType1 = (BaseUnionType)unionTypeBuilder1.build();
370         final BaseUnionType baseUnionType2 = (BaseUnionType)unionTypeBuilder2.build();
371         hashCodeEqualsToStringTest(baseUnionType1, baseUnionType2);
372         assertEquals(baseUnionType1.getTypes(), baseUnionType2.getTypes());
373
374         final DerivedUnionType derivedUnionType1 = (DerivedUnionType)DerivedTypes
375                 .derivedTypeBuilder(baseUnionType1, SCHEMA_PATH).build();
376         final DerivedUnionType derivedUnionType2 = (DerivedUnionType)DerivedTypes
377                 .derivedTypeBuilder(baseUnionType2, SCHEMA_PATH).build();
378         hashCodeEqualsToStringTest(derivedUnionType1, derivedUnionType2);
379
380         restrictedBuilderTest(RestrictedTypes.newUnionBuilder(baseUnionType1, SCHEMA_PATH),
381                 RestrictedTypes.newUnionBuilder(baseUnionType2, SCHEMA_PATH));
382         concreteBuilderTest(baseUnionType1, derivedUnionType1);
383     }
384
385     @Test
386     public void abstractTypeDefinitionQnameTest() {
387         final AbstractTypeDefinition<?> abstractTypeDefinition = (AbstractTypeDefinition<?>)
388             BaseTypes.decimalTypeBuilder(SCHEMA_PATH).setFractionDigits(1).buildType();
389         assertEquals(abstractTypeDefinition.getQName(), Q_NAME);
390     }
391
392     @Test
393     public void abstractDerivedTypeTest() {
394         final BaseBinaryType baseBinaryType1 = BaseBinaryType.INSTANCE;
395         final AbstractDerivedType<?> abstractDerivedType = (AbstractDerivedType<?>)
396             DerivedTypes.derivedTypeBuilder(baseBinaryType1, SCHEMA_PATH).build();
397         assertEquals(Optional.empty(), abstractDerivedType.getDescription());
398         assertEquals(Optional.empty(), abstractDerivedType.getReference());
399         assertEquals(Status.CURRENT, abstractDerivedType.getStatus());
400     }
401
402     @Test
403     public void concreteTypeBuilderBuildTest() {
404         final BaseEnumerationType baseEnumerationType1 = (BaseEnumerationType)
405             BaseTypes.enumerationTypeBuilder(SCHEMA_PATH).build();
406         final ConcreteTypeBuilder<?> concreteTypeBuilder = ConcreteTypes.concreteTypeBuilder(
407                 baseEnumerationType1, SCHEMA_PATH);
408         final TypeDefinition<?> typeDefinition = concreteTypeBuilder.build();
409         assertNotNull(typeDefinition);
410     }
411
412     @Test
413     public void constraintTypeBuilderTest() throws InvalidLengthConstraintException {
414         final BaseBinaryType baseBinaryType = (BaseBinaryType)BaseTypes.binaryType();
415         final LengthRestrictedTypeBuilder<?> lengthRestrictedTypeBuilder = RestrictedTypes
416                 .newBinaryBuilder(baseBinaryType, SCHEMA_PATH);
417         final Long min = Long.valueOf(0);
418         final UnresolvedNumber max = UnresolvedNumber.max();
419         final List<ValueRange> lengthArrayList = ImmutableList.of(ValueRange.of(min, max));
420         lengthRestrictedTypeBuilder.setLengthConstraint(mock(ConstraintMetaDefinition.class), lengthArrayList);
421         final TypeDefinition<?> typeDefinition = lengthRestrictedTypeBuilder.buildType();
422         assertNotNull(typeDefinition);
423
424         final Int8TypeDefinition integerTypeDefinition8 = BaseTypes.int8Type();
425         final RangeRestrictedTypeBuilder<?, ?> rangeRestrictedTypeBuilder = RestrictedTypes.newInt8Builder(
426             integerTypeDefinition8, SCHEMA_PATH);
427         rangeRestrictedTypeBuilder.setRangeConstraint(mock(ConstraintMetaDefinition.class), lengthArrayList);
428         final TypeDefinition<?> typeDefinition1 = rangeRestrictedTypeBuilder.buildType();
429         assertNotNull(typeDefinition1);
430     }
431
432     @Test
433     public void exceptionTest() {
434         final UnresolvedNumber min = UnresolvedNumber.min();
435         final UnresolvedNumber max = UnresolvedNumber.max();
436         final EnumPair enumPair = EnumPairBuilder.create("enum1", 1).setDescription("description")
437                 .setReference("reference").setUnknownSchemaNodes(mock(UnknownSchemaNode.class)).build();
438
439         final RangeSet<Integer> rangeset = ImmutableRangeSet.of(Range.closed(1, 2));
440         final InvalidRangeConstraintException invalidRangeConstraintException = new InvalidRangeConstraintException(
441                 rangeset, "error msg", "other important messages");
442         assertSame(rangeset, invalidRangeConstraintException.getOffendingRanges());
443
444         final InvalidBitDefinitionException invalidBitDefinitionException = new InvalidBitDefinitionException(
445                 BIT_A, "error msg", "other important messages");
446         assertEquals(invalidBitDefinitionException.getOffendingBit(), BIT_A);
447
448         final InvalidEnumDefinitionException invalidEnumDefinitionException = new InvalidEnumDefinitionException(
449                 enumPair, "error msg", "other important messages");
450         assertEquals(invalidEnumDefinitionException.getOffendingEnum(), enumPair);
451     }
452
453     @Test(expected = IllegalStateException.class)
454     public void identityrefTypeBuilderException() {
455         BaseTypes.identityrefTypeBuilder(SCHEMA_PATH).build();
456     }
457
458     @Test(expected = InvalidBitDefinitionException.class)
459     public void invalidBitDefinitionExceptionTest() {
460         final BitsTypeBuilder bitsTypeBuilder = BaseTypes.bitsTypeBuilder(SCHEMA_PATH);
461         final QName qName = QName.create("test.namespace.1", "2016-01-02", "test-name-1");
462         final SchemaPath schemaPath = SchemaPath.create(true, qName);
463         bitsTypeBuilder.addBit(BIT_A);
464         bitsTypeBuilder.addBit(BitBuilder.create(schemaPath, 55L).build());
465         bitsTypeBuilder.build();
466     }
467
468     @Test(expected = InvalidEnumDefinitionException.class)
469     public void invalidEnumDefinitionExceptionTest() {
470         final UnknownSchemaNode unknown = mock(UnknownSchemaNode.class);
471         final EnumPair enumPair1 = EnumPairBuilder.create("enum1", 1).setDescription("description")
472                 .setReference("reference").setUnknownSchemaNodes(unknown).build();
473         final EnumPair enumPair2 = EnumPairBuilder.create("enum", 1).setDescription("description")
474                 .setReference("reference").setUnknownSchemaNodes(unknown).build();
475         final EnumerationTypeBuilder enumerationTypeBuilder = BaseTypes.enumerationTypeBuilder(SCHEMA_PATH);
476         enumerationTypeBuilder.addEnum(enumPair1);
477         enumerationTypeBuilder.addEnum(enumPair2);
478         enumerationTypeBuilder.build();
479     }
480
481     private static void hashCodeEqualsToStringTest(final TypeDefinition<?> type1, final TypeDefinition<?> type2) {
482         assertEquals(type1.hashCode(), type2.hashCode());
483         assertEquals(type1.toString(), type2.toString());
484         assertTrue(type1.equals(type2));
485     }
486
487     private static <T> void testInstance(final T type1, final T type2) {
488         assertEquals(type1, type2);
489     }
490
491     private static void restrictedBuilderTest(final Builder<?> typeBuilder1, final Builder<?> typeBuilder2) {
492         final TypeDefinition<?> typeDefinition1 = ((AbstractRestrictedTypeBuilder<?>) typeBuilder1).buildType();
493         final TypeDefinition<?> typeDefinition2 = ((AbstractRestrictedTypeBuilder<?>) typeBuilder2).buildType();
494         hashCodeEqualsToStringTest(typeDefinition1, typeDefinition2);
495     }
496
497     private static void concreteBuilderTest(final TypeDefinition<?> baseTypeDef,
498             final TypeDefinition<?> derivedTypeDef) {
499         final ConcreteTypeBuilder<?> concreteTypeBuilder = ConcreteTypes.concreteTypeBuilder(baseTypeDef, SCHEMA_PATH);
500         final TypeDefinition<?> typeDefinition = concreteTypeBuilder.buildType();
501         assertEquals(typeDefinition.getBaseType(), derivedTypeDef.getBaseType());
502     }
503 }