本文整理匯總了Java中org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType類的典型用法代碼示例。如果您正苦於以下問題:Java TreeType類的具體用法?Java TreeType怎麽用?Java TreeType使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
TreeType類屬於org.opendaylight.yangtools.yang.data.api.schema.tree包,在下文中一共展示了TreeType類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: InMemoryDOMDataStore
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
public InMemoryDOMDataStore(final String name, final LogicalDatastoreType type,
final ExecutorService dataChangeListenerExecutor,
final int maxDataChangeListenerQueueSize, final boolean debugTransactions) {
this.name = Preconditions.checkNotNull(name);
this.dataChangeListenerExecutor = Preconditions.checkNotNull(dataChangeListenerExecutor);
this.debugTransactions = debugTransactions;
dataChangeListenerNotificationManager =
new QueuedNotificationManager<>(this.dataChangeListenerExecutor,
DCL_NOTIFICATION_MGR_INVOKER, maxDataChangeListenerQueueSize,
"DataChangeListenerQueueMgr");
changePublisher = new InMemoryDOMStoreTreeChangePublisher(this.dataChangeListenerExecutor, maxDataChangeListenerQueueSize);
switch (type) {
case CONFIGURATION:
dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.CONFIGURATION);
break;
case OPERATIONAL:
dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL);
break;
default:
throw new IllegalArgumentException("Data store " + type + " not supported");
}
}
示例2: DistributedShardChangePublisher
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
public DistributedShardChangePublisher(final DataStoreClient client,
final AbstractDataStore distributedDataStore,
final DOMDataTreeIdentifier prefix,
final Map<DOMDataTreeIdentifier, ChildShardContext> childShards) {
this.distributedDataStore = distributedDataStore;
// TODO keeping the whole dataTree thats contained in subshards doesn't seem like a good idea
// maybe the whole listener logic would be better in the backend shards where we have direct access to the
// dataTree and wont have to cache it redundantly.
this.dataTree = InMemoryDataTreeFactory.getInstance().create(
TreeType.valueOf(prefix.getDatastoreType().name()), prefix.getRootIdentifier());
dataTree.setSchemaContext(distributedDataStore.getActorContext().getSchemaContext());
this.shardPath = prefix.getRootIdentifier();
this.childShards = childShards;
}
示例3: createSnapshot
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
private static ShardSnapshotState createSnapshot() {
final TipProducingDataTree dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL);
dataTree.setSchemaContext(SchemaContextHelper.select(SchemaContextHelper.CARS_YANG,
SchemaContextHelper.PEOPLE_YANG));
DataTreeSnapshot snapshot = dataTree.takeSnapshot();
DataTreeModification modification = snapshot.newModification();
modification.merge(CarsModel.BASE_PATH, CarsModel.create());
modification.merge(PeopleModel.BASE_PATH, PeopleModel.create());
modification.ready();
dataTree.commit(dataTree.prepare(modification));
return new ShardSnapshotState(new MetadataShardDataTreeSnapshot(dataTree.takeSnapshot().readNode(
YangInstanceIdentifier.EMPTY).get()));
}
示例4: setUp
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Before
public void setUp() {
MockitoAnnotations.initMocks(this);
dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.CONFIGURATION);
dataTree.setSchemaContext(SCHEMA_CONTEXT);
realModification = dataTree.takeSnapshot().newModification();
proxyModification = Reflection.newProxy(DataTreeModification.class, (proxy, method, args) -> {
try {
method.invoke(mockModification, args);
return method.invoke(realModification, args);
} catch (InvocationTargetException e) {
throw e.getCause();
}
});
pruningDataTreeModification = new PruningDataTreeModification(proxyModification, dataTree, SCHEMA_CONTEXT);
}
示例5: testWriteRootNode
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Test
public void testWriteRootNode() throws Exception {
final DataTree localDataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.CONFIGURATION);
localDataTree.setSchemaContext(SCHEMA_CONTEXT);
DataTreeModification mod = localDataTree.takeSnapshot().newModification();
mod.write(CarsModel.BASE_PATH, CarsModel.create());
mod.ready();
localDataTree.validate(mod);
localDataTree.commit(localDataTree.prepare(mod));
NormalizedNode<?, ?> normalizedNode = dataTree.takeSnapshot().readNode(YangInstanceIdentifier.EMPTY).get();
pruningDataTreeModification.write(YangInstanceIdentifier.EMPTY, normalizedNode);
dataTree.commit(getCandidate());
Optional<NormalizedNode<?, ?>> actual = dataTree.takeSnapshot().readNode(YangInstanceIdentifier.EMPTY);
assertEquals("Root present", true, actual.isPresent());
assertEquals("Root node", normalizedNode, actual.get());
}
示例6: testWriteRootNodeWithInvalidChild
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Test
public void testWriteRootNodeWithInvalidChild() throws Exception {
final Shard mockShard = Mockito.mock(Shard.class);
ShardDataTree shardDataTree = new ShardDataTree(mockShard, SCHEMA_CONTEXT, TreeType.CONFIGURATION);
NormalizedNode<?, ?> root = shardDataTree.readNode(YangInstanceIdentifier.EMPTY).get();
NormalizedNode<?, ?> normalizedNode = ImmutableContainerNodeBuilder.create().withNodeIdentifier(
new YangInstanceIdentifier.NodeIdentifier(root.getNodeType())).withChild(
ImmutableNodes.containerNode(AUG_CONTAINER)).build();
pruningDataTreeModification.write(YangInstanceIdentifier.EMPTY, normalizedNode);
dataTree.commit(getCandidate());
Optional<NormalizedNode<?, ?>> actual = dataTree.takeSnapshot().readNode(YangInstanceIdentifier.EMPTY);
assertEquals("Root present", true, actual.isPresent());
assertEquals("Root node", root, actual.get());
}
示例7: from
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
public static ModificationApplyOperation from(final DataSchemaNode schemaNode,
final DataTreeConfiguration treeConfig) {
if (treeConfig.getTreeType() == TreeType.CONFIGURATION) {
Preconditions.checkArgument(schemaNode.isConfiguration(),
"Supplied %s does not belongs to configuration tree.", schemaNode.getPath());
}
if (schemaNode instanceof ContainerSchemaNode) {
final ContainerSchemaNode containerSchema = (ContainerSchemaNode) schemaNode;
if (containerSchema.isPresenceContainer()) {
return new PresenceContainerModificationStrategy(containerSchema, treeConfig);
}
return new StructuralContainerModificationStrategy(containerSchema, treeConfig);
} else if (schemaNode instanceof ListSchemaNode) {
return fromListSchemaNode((ListSchemaNode) schemaNode, treeConfig);
} else if (schemaNode instanceof ChoiceSchemaNode) {
return new ChoiceModificationStrategy((ChoiceSchemaNode) schemaNode, treeConfig);
} else if (schemaNode instanceof LeafListSchemaNode) {
return fromLeafListSchemaNode((LeafListSchemaNode) schemaNode, treeConfig);
} else if (schemaNode instanceof LeafSchemaNode) {
return new LeafModificationStrategy((LeafSchemaNode) schemaNode);
}
throw new IllegalArgumentException("Not supported schema node type for " + schemaNode.getClass());
}
示例8: forTree
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
static CaseEnforcer forTree(final CaseSchemaNode schema, final DataTreeConfiguration treeConfig) {
final TreeType type = treeConfig.getTreeType();
final Builder<NodeIdentifier, DataSchemaNode> childrenBuilder = ImmutableMap.builder();
final Builder<AugmentationIdentifier, AugmentationSchemaNode> augmentationsBuilder = ImmutableMap.builder();
if (SchemaAwareApplyOperation.belongsToTree(type, schema)) {
for (final DataSchemaNode child : schema.getChildNodes()) {
if (SchemaAwareApplyOperation.belongsToTree(type, child)) {
childrenBuilder.put(NodeIdentifier.create(child.getQName()), child);
}
}
for (final AugmentationSchemaNode augment : schema.getAvailableAugmentations()) {
if (augment.getChildNodes().stream()
.anyMatch(child -> SchemaAwareApplyOperation.belongsToTree(type, child))) {
augmentationsBuilder.put(SchemaUtils.getNodeIdentifierForAugmentation(augment), augment);
}
}
}
final Map<NodeIdentifier, DataSchemaNode> children = childrenBuilder.build();
final Map<AugmentationIdentifier, AugmentationSchemaNode> augmentations = augmentationsBuilder.build();
return children.isEmpty() ? null
: new CaseEnforcer(children, augmentations, MandatoryLeafEnforcer.forContainer(schema, treeConfig));
}
示例9: getTreeType
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
public TreeType getTreeType() {
switch (datastoreContext.getLogicalStoreType()) {
case CONFIGURATION:
return TreeType.CONFIGURATION;
case OPERATIONAL:
return TreeType.OPERATIONAL;
default:
throw new IllegalStateException("Unhandled logical store type "
+ datastoreContext.getLogicalStoreType());
}
}
示例10: NormalizedNodeAggregator
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
private NormalizedNodeAggregator(final YangInstanceIdentifier rootIdentifier,
final List<Optional<NormalizedNode<?, ?>>> nodes, final SchemaContext schemaContext,
LogicalDatastoreType logicalDatastoreType) {
this.rootIdentifier = rootIdentifier;
this.nodes = nodes;
this.dataTree = InMemoryDataTreeFactory.getInstance().create(
logicalDatastoreType == LogicalDatastoreType.CONFIGURATION ? TreeType.CONFIGURATION :
TreeType.OPERATIONAL);
this.dataTree.setSchemaContext(schemaContext);
}
示例11: ShardDataTree
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
ShardDataTree(final Shard shard, final SchemaContext schemaContext, final TreeType treeType,
final YangInstanceIdentifier root,
final ShardDataTreeChangeListenerPublisher treeChangeListenerPublisher,
final ShardDataChangeListenerPublisher dataChangeListenerPublisher, final String logContext,
final ShardDataTreeMetadata<?>... metadata) {
this(shard, schemaContext, InMemoryDataTreeFactory.getInstance().create(treeType, root),
treeChangeListenerPublisher, dataChangeListenerPublisher, logContext, metadata);
}
示例12: setUp
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Before
public void setUp() {
peopleSchemaContext = SchemaContextHelper.select(SchemaContextHelper.PEOPLE_YANG);
carsSchemaContext = SchemaContextHelper.select(SchemaContextHelper.CARS_YANG);
final Shard mockShard = Mockito.mock(Shard.class);
peopleDataTree = new ShardDataTree(mockShard, peopleSchemaContext, TreeType.OPERATIONAL);
coordinator = ShardRecoveryCoordinator.create(peopleDataTree, "foobar", FOO_LOGGER);
coordinator.startLogRecoveryBatch(10);
}
示例13: createCar
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
private DataTreeCandidateTip createCar() {
final TipProducingDataTree dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL);
dataTree.setSchemaContext(carsSchemaContext);
final DataTreeSnapshot snapshot = dataTree.takeSnapshot();
final DataTreeModification modification = snapshot.newModification();
modification.merge(CarsModel.BASE_PATH, CarsModel.create());
modification.ready();
return dataTree.prepare(modification);
}
示例14: newSnapshot
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
private static Snapshot newSnapshot(YangInstanceIdentifier path, NormalizedNode<?, ?> node)
throws Exception {
DataTree dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.OPERATIONAL);
dataTree.setSchemaContext(SchemaContextHelper.full());
AbstractShardTest.writeToStore(dataTree, path, node);
NormalizedNode<?, ?> root = AbstractShardTest.readStore(dataTree, YangInstanceIdentifier.EMPTY);
return Snapshot.create(new ShardSnapshotState(new MetadataShardDataTreeSnapshot(root)),
Collections.<ReplicatedLogEntry>emptyList(), 2, 1, 2, 1, 1, "member-1", null);
}
示例15: testUnmodifiedRootCandidate
import org.opendaylight.yangtools.yang.data.api.schema.tree.TreeType; //導入依賴的package包/類
@Test
public void testUnmodifiedRootCandidate() throws Exception {
final TipProducingDataTree dataTree = InMemoryDataTreeFactory.getInstance().create(TreeType.CONFIGURATION);
dataTree.setSchemaContext(SchemaContextHelper.select(SchemaContextHelper.CARS_YANG));
DataTreeModification modification = dataTree.takeSnapshot().newModification();
modification.ready();
candidate = dataTree.prepare(modification);
CommitTransactionPayload payload = CommitTransactionPayload.create(nextTransactionId(), candidate);
assertCandidateEquals(candidate, payload.getCandidate().getValue());
}