org.gradle.model.internal.registry.RegistrySpec.groovy Maven / Gradle / Ivy
/*
* Copyright 2015 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.gradle.model.internal.registry
import com.google.common.base.Predicate
import org.gradle.api.Nullable
import org.gradle.model.RuleSource
import org.gradle.model.internal.core.*
import org.gradle.model.internal.core.rule.describe.ModelRuleDescriptor
import org.gradle.model.internal.core.rule.describe.SimpleModelRuleDescriptor
import org.gradle.model.internal.type.ModelType
import spock.lang.Specification
abstract class RegistrySpec extends Specification {
protected static class TestNode extends ModelNodeInternal {
def links = []
TestNode(String creationPath, Class> type) {
super(null, ModelRegistrations.of(ModelPath.path(creationPath)).descriptor("test").build())
addProjection(new UnmanagedModelProjection(ModelType.of(type)))
}
TestNode(ModelRegistration registration) {
super(null, registration)
}
@Override
Iterable extends ModelNodeInternal> getLinks() {
return links
}
ModelNodeInternal addLink(ModelNodeInternal node) {
links << node
return node
}
@Override
def ModelView extends T> asMutable(ModelType type, ModelRuleDescriptor ruleDescriptor) {
return null
}
@Override
def void addReference(String name, ModelType type, ModelNode target, ModelRuleDescriptor ruleDescriptor) {
}
@Override
void addLink(ModelRegistration registration) {
}
@Override
void removeLink(String name) {
}
@Override
def void applyToLink(ModelActionRole type, ModelAction action) {
}
@Override
void applyTo(NodePredicate predicate, ModelActionRole role, ModelAction action) {
}
@Override
void applyTo(NodePredicate predicate, Class extends RuleSource> rules) {
}
@Override
ModelNodeInternal getLink(String name) {
return null
}
@Override
int getLinkCount(Predicate super MutableModelNode> predicate) {
return 0
}
@Override
Iterable extends MutableModelNode> getLinks(Predicate super MutableModelNode> predicate) {
return null
}
@Override
Set getLinkNames(Predicate super MutableModelNode> predicate) {
return null
}
@Override
Set getLinkNames() {
[]
}
@Override
int getLinkCount() {
return 0
}
@Override
boolean hasLink(String name) {
return false
}
@Override
boolean hasLink(String name, Predicate super MutableModelNode> predicate) {
return false
}
@Override
def void setPrivateData(ModelType super T> type, T object) {
}
@Override
def void setPrivateData(Class super T> type, T object) {
}
@Override
def T getPrivateData(ModelType type) {
return null
}
@Override
def T getPrivateData(Class type) {
return null
}
@Override
Object getPrivateData() {
return null
}
@Override
void setTarget(ModelNode target) {
}
@Override
void ensureUsable() {
}
@Override
void ensureAtLeast(ModelNode.State state) {
}
@Override
def ModelView extends T> asImmutable(ModelType type, @Nullable ModelRuleDescriptor ruleDescriptor) {
return null
}
@Override
MutableModelNode getParent() {
return null
}
}
protected static class RuleBinderTestBuilder {
private ModelRuleDescriptor descriptor
private BindingPredicate subjectReference
private String subjectReferenceBindingPath
private List inputReferences = []
private Map boundInputReferencePaths = [:]
void subjectReference(ModelReference> reference) {
subjectReference = new BindingPredicate(reference)
}
void subjectReference(Class type) {
subjectReference(ModelReference.of(ModelType.of(type)))
}
void subjectReference(String path, Class type) {
subjectReference(ModelReference.of(new ModelPath(path), ModelType.of(type)))
}
void bindSubjectReference(String path) {
subjectReferenceBindingPath = path
}
void inputReference(ModelReference> reference) {
inputReferences.add(new BindingPredicate(reference))
}
void inputReference(Class type) {
inputReference(ModelReference.of(ModelType.of(type)).inScope(ModelPath.ROOT))
}
void inputReference(Class type, ModelNode.State state) {
inputReference(ModelReference.of(null, ModelType.of(type), state).inScope(ModelPath.ROOT))
}
void inputReference(String path, ModelNode.State state) {
inputReference(ModelReference.of(ModelPath.path(path), ModelType.untyped(), state))
}
void inputReference(String path, Class type) {
inputReference(ModelReference.of(new ModelPath(path), ModelType.of(type)))
}
void bindInputReference(int index, String path) {
boundInputReferencePaths[index] = path
}
void descriptor(String descriptor) {
this.descriptor = new SimpleModelRuleDescriptor(descriptor)
}
RuleBinder build() {
def action = NoInputsModelAction.of(subjectReference.reference, descriptor, {})
def binder = new RuleBinder(subjectReference, inputReferences, action, [])
if (subjectReferenceBindingPath) {
binder.subjectBinding.boundTo = new TestNode(subjectReferenceBindingPath, Object)
}
boundInputReferencePaths.each { index, path ->
binder.inputBindings[index].boundTo = new TestNode(path, Object)
}
return binder
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy