/*
* Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
package org.opendaylight.yangtools.yang.parser.stmt.rfc7950;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Iterables;
import java.util.List;
import org.junit.Test;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.model.api.LeafSchemaNode;
import org.opendaylight.yangtools.yang.model.api.SchemaContext;
import org.opendaylight.yangtools.yang.model.api.SchemaNode;
import org.opendaylight.yangtools.yang.model.api.SchemaPath;
import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
import org.opendaylight.yangtools.yang.model.api.type.ModifierKind;
import org.opendaylight.yangtools.yang.model.api.type.PatternConstraint;
import org.opendaylight.yangtools.yang.model.api.type.StringTypeDefinition;
import org.opendaylight.yangtools.yang.model.util.SchemaContextUtil;
import org.opendaylight.yangtools.yang.parser.spi.meta.SomeModifiersUnresolvedException;
import org.opendaylight.yangtools.yang.stmt.StmtTestUtils;
public class Bug6870Test {
private static final String FOO_NS = "foo";
private static final String FOO_REV = "1970-01-01";
@Test
public void valid11Test() throws Exception {
final SchemaContext schemaContext = StmtTestUtils.parseYangSource("/rfc7950/bug6870/foo.yang");
assertNotNull(schemaContext);
assertModifier(schemaContext, ModifierKind.INVERT_MATCH, ImmutableList.of("root", "my-leaf"));
assertModifier(schemaContext, null, ImmutableList.of("root", "my-leaf-2"));
}
private static void assertModifier(final SchemaContext schemaContext, final ModifierKind expectedModifierKind,
final List<String> localNamePath) {
final SchemaNode findNode = findNode(schemaContext, localNamePath);
assertTrue(findNode instanceof LeafSchemaNode);
final LeafSchemaNode myLeaf = (LeafSchemaNode) findNode;
final TypeDefinition<? extends TypeDefinition<?>> type = myLeaf.getType();
assertTrue(type instanceof StringTypeDefinition);
final StringTypeDefinition stringType = (StringTypeDefinition) type;
final List<PatternConstraint> patternConstraints = stringType.getPatternConstraints();
assertEquals(1, patternConstraints.size());
final PatternConstraint patternConstraint = patternConstraints.iterator().next();
assertEquals(expectedModifierKind, patternConstraint.getModifier());
}
private static SchemaNode findNode(final SchemaContext context, final Iterable<String> localNamesPath) {
final Iterable<QName> qNames = Iterables.transform(localNamesPath,
localName -> QName.create(FOO_NS, FOO_REV, localName));
return SchemaContextUtil.findDataSchemaNode(context, SchemaPath.create(qNames, true));
}
@Test
public void invalid11Test() throws Exception {
try {
StmtTestUtils.parseYangSource("/rfc7950/bug6870/invalid11.yang");
fail("Test should fail due to invalid Yang 1.1");
} catch (final SomeModifiersUnresolvedException e) {
assertTrue(e.getCause().getMessage()
.startsWith("'Invert-match' is not valid argument of modifier statement"));
}
}
@Test
public void invalid10Test() throws Exception {
try {
StmtTestUtils.parseYangSource("/rfc7950/bug6870/invalid10.yang");
fail("Test should fail due to invalid Yang 1.0");
} catch (final SomeModifiersUnresolvedException e) {
assertTrue(e.getCause().getMessage().startsWith("modifier is not a YANG statement or use of extension"));
}
}
}