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