Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.gradle.test.fixtures.GradleModuleMetadata.groovy Maven / Gradle / Ivy
/*
* Copyright 2017 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.test.fixtures
import com.google.gson.stream.JsonReader
import com.google.gson.stream.JsonToken
import groovy.transform.Canonical
import org.gradle.internal.hash.HashValue
import org.gradle.test.fixtures.file.TestFile
import org.gradle.util.GradleVersion
import javax.annotation.Nullable
class GradleModuleMetadata {
private Map values
private List variants
GradleModuleMetadata(TestFile file) {
file.withReader { r ->
JsonReader reader = new JsonReader(r)
values = readObject(reader)
}
assert values.formatVersion == '0.4'
assert values.createdBy.gradle.version == GradleVersion.current().version
assert values.createdBy.gradle.buildId
variants = (values.variants ?: []).collect { new Variant(it.name, it) }
}
@Nullable
Coords getComponent() {
def comp = values.component
if (comp == null || comp.url) {
return null
}
return new Coords(comp.group, comp.module, comp.version)
}
@Nullable
ModuleReference getOwner() {
def comp = values.component
if (comp == null || !comp.url) {
return null
}
return new ModuleReference(comp.group, comp.module, comp.version, comp.url)
}
Map getAttributes() {
values.component?.attributes
}
List getVariants() {
return variants
}
Variant variant(String name) {
def matches = variants.findAll { it.name == name }
assert matches.size() == 1 : "Variant '$name' not found"
return matches.first()
}
Variant variant(String name, @DelegatesTo(value=Variant, strategy=Closure.DELEGATE_FIRST) Closure action) {
def variant = variant(name)
action.delegate = variant
action.resolveStrategy = Closure.DELEGATE_FIRST
action()
variant
}
private Map readObject(JsonReader reader) {
Map values = [:]
reader.beginObject()
while (reader.peek() != JsonToken.END_OBJECT) {
String name = reader.nextName()
Object value = readAny(reader)
values.put(name, value)
}
reader.endObject()
return values
}
private Object readAny(JsonReader reader) {
Object value = null
switch (reader.peek()) {
case JsonToken.NULL:
reader.nextNull()
break
case JsonToken.STRING:
value = reader.nextString()
break
case JsonToken.BOOLEAN:
value = reader.nextBoolean()
break
case JsonToken.NUMBER:
value = reader.nextLong()
break
case JsonToken.BEGIN_OBJECT:
value = readObject(reader)
break
case JsonToken.BEGIN_ARRAY:
value = readArray(reader)
break
}
value
}
private List readArray(JsonReader reader) {
List values = []
reader.beginArray()
while (reader.peek() != JsonToken.END_ARRAY) {
Object value = readAny(reader)
values.add(value)
}
reader.endArray()
return values
}
static Map normalizeForTests(Map attributes) {
attributes?.collectEntries { k, v -> [k, v?.toString()] }
}
static class Variant {
final String name
private final Map values
List dependencies
final Set checkedDependencies = []
List dependencyConstraints
final Set checkedDependencyConstraints = []
List capabilities
final Set checkedCapabilities = []
Variant(String name, Map values) {
this.name = name
this.values = values
}
@Nullable
ModuleReference getAvailableAt() {
def ref = values['available-at']
return ref == null ? null : new ModuleReference(ref.group, ref.module, ref.version, ref.url)
}
List getDependencies() {
if (dependencies == null) {
dependencies = (values.dependencies ?: []).collect {
def exclusions = it.excludes ? it.excludes.collect { "${it.group}:${it.module}" } : []
new Dependency(it.group, it.module, it.version?.requires, it.version?.prefers, it.version?.strictly, it.version?.rejects ?: [], exclusions, it.reason, normalizeForTests(it.attributes))
}
}
dependencies
}
Variant noMoreDependencies() {
Set uncheckedDependencies = getDependencies() - checkedDependencies
assert uncheckedDependencies.empty
Set uncheckedDependencyConstraints = getDependencyConstraints() - checkedDependencyConstraints
assert uncheckedDependencyConstraints.empty
this
}
List getDependencyConstraints() {
if (dependencyConstraints == null) {
dependencyConstraints = (values.dependencyConstraints ?: []).collect {
new DependencyConstraint(it.group, it.module, it.version.requires, it.version.prefers, it.version.strictly, it.version.rejects ?: [], it.reason, normalizeForTests(it.attributes))
}
}
dependencyConstraints
}
List getFiles() {
return (values.files ?: []).collect { new File(it.name, it.url, it.size, new HashValue(it.sha1), new HashValue(it.md5)) }
}
DependencyView dependency(String group, String module, String version, @DelegatesTo(value=DependencyView, strategy= Closure.DELEGATE_FIRST) Closure action = { exists() }) {
def view = new DependencyView(group, module, version)
action.delegate = view
action.resolveStrategy = Closure.DELEGATE_FIRST
action()
view
}
DependencyView dependency(String notation, @DelegatesTo(value=DependencyView, strategy= Closure.DELEGATE_FIRST) Closure action = { exists() }) {
def (String group, String module, String version) = notation.split(':') as List
dependency(group, module, version, action)
}
DependencyConstraintView constraint(String group, String module, String version, @DelegatesTo(value=DependencyView, strategy= Closure.DELEGATE_FIRST) Closure action = { exists() }) {
def view = new DependencyConstraintView(group, module, version)
action.delegate = view
action.resolveStrategy = Closure.DELEGATE_FIRST
action()
view
}
DependencyConstraintView constraint(String notation, @DelegatesTo(value=DependencyConstraintView, strategy= Closure.DELEGATE_FIRST) Closure action = { exists() }) {
def (String group, String module, String version) = notation.split(':') as List
constraint(group, module, version, action)
}
List getCapabilities() {
if (capabilities == null) {
capabilities = (values.capabilities ?: []).collect {
new Capability(it.group, it.name, it.version)
}
}
capabilities
}
Variant capability(String group, String name, String version) {
def cap = getCapabilities().find { it.group == group && it.name == name && it.version == version}
assert cap : "capability ${group}:${name}:${version} not found in ${getCapabilities()}"
checkedCapabilities << cap
this
}
Variant noMoreCapabilities() {
Set uncheckedCapabilities = getCapabilities() - checkedCapabilities
assert uncheckedCapabilities.empty
this
}
class DependencyView {
final String group
final String module
final String version
final Set checkedExcludes = []
DependencyView(String gid, String mid, String v) {
group = gid
module = mid
version = v
}
Dependency find() {
def dep = dependencies.find { it.group == group && it.module == module && it.version == version }
assert dep : "dependency ${group}:${module}:${version} not found in $dependencies"
checkedDependencies << dep
dep
}
DependencyView exists() {
assert find()
this
}
DependencyView hasExclude(String group, String module = '*') {
String exc = "${group}:${module}"
assert find()?.excludes?.contains(exc)
checkedExcludes << exc
this
}
DependencyView noMoreExcludes() {
def uncheckedExcludes = find().excludes - checkedExcludes
assert uncheckedExcludes.empty
this
}
DependencyView notTransitive() {
hasExclude('*', '*')
noMoreExcludes()
}
DependencyView prefers(String version = null) {
String actualPrefers = find()?.prefers
assert actualPrefers == version
this
}
DependencyView strictly(String version = null) {
String actualStrictly = find()?.strictly
assert actualStrictly == version
this
}
DependencyView rejects(String... rejections) {
Set actualRejects = find()?.rejectsVersion
Set expectedRejects = rejections as Set
assert actualRejects == expectedRejects
this
}
DependencyView hasReason(String reason) {
assert find()?.reason == reason
this
}
DependencyView hasAttribute(String attribute) {
assert find()?.attributes?.containsKey(attribute)
this
}
DependencyView hasAttribute(String attribute, Object value) {
String expected = value?.toString()
assert find()?.attributes[attribute] == expected
this
}
DependencyView hasAttributes(Map fullAttributeSet) {
Map expectedAttributes = normalizeForTests(fullAttributeSet)
def actualAttributes = find()?.attributes
assert actualAttributes == expectedAttributes
this
}
}
class DependencyConstraintView {
final String group
final String module
final String version
DependencyConstraintView(String gid, String mid, String v) {
group = gid
module = mid
version = v
}
DependencyConstraint find() {
def depConstraint = dependencyConstraints.find { it.group == group && it.module == module && it.version == version }
assert depConstraint : "constraint ${group}:${module}:${version} not found in $dependencyConstraints"
checkedDependencyConstraints << depConstraint
depConstraint
}
DependencyConstraintView exists() {
assert find()
this
}
DependencyConstraintView prefers(String version) {
String actualPrefers = find()?.prefers
assert actualPrefers == version
this
}
DependencyConstraintView strictly(String version) {
String actualStrictly = find()?.strictly
assert actualStrictly == version
this
}
DependencyConstraintView rejects(String... rejections) {
Set actualRejects = find()?.rejectsVersion
Set expectedRejects = rejections as Set
assert actualRejects == expectedRejects
this
}
DependencyConstraintView hasReason(String reason) {
assert find()?.reason == reason
this
}
DependencyConstraintView hasAttribute(String attribute) {
assert find()?.attributes?.containsKey(attribute)
this
}
DependencyConstraintView hasAttribute(String attribute, Object value) {
String expected = value?.toString()
assert find()?.attributes[attribute] == expected
this
}
DependencyConstraintView hasAttributes(Map fullAttributeSet) {
Map expectedAttributes = normalizeForTests(fullAttributeSet)
def actualAttributes = find()?.attributes
assert actualAttributes == expectedAttributes
this
}
}
}
static class Coords {
final String group
final String module
final String version
final String prefers
final String strictly
final List rejectsVersion
final String reason
final Map attributes
Coords(String group, String module, String version, String prefers = '', String strictly = '', List rejectsVersion = [], String reason = null, Map attributes = [:]) {
this.group = group
this.module = module
this.version = version
this.prefers = prefers
this.strictly = strictly
this.rejectsVersion = rejectsVersion
this.reason = reason
this.attributes = attributes
}
String getCoords() {
return "$group:$module:${version ?: prefers ?: ''}"
}
String toString() {
coords
}
}
static class ModuleReference extends Coords {
final String url
ModuleReference(String group, String module, String version, String url) {
super(group, module, version)
this.url = url
}
String toString() {
"${coords} ${url?url:''}"
}
}
static class Dependency extends Coords {
final List excludes
Dependency(String group, String module, String requires, String prefers, String strictly, List rejectedVersions, List excludes, String reason, Map attributes) {
super(group, module, requires, prefers, strictly, rejectedVersions, reason, attributes)
this.excludes = excludes*.toString()
}
String toString() {
def exc = ""
if (excludes) {
exc = excludes.collect { " excludes $it" }.join(', ')
}
"${coords}${exc}"
}
}
static class DependencyConstraint extends Coords {
DependencyConstraint(String group, String module, String version, String prefers, String strictly, List rejectedVersions, String reason, Map attributes) {
super(group, module, version, prefers, strictly, rejectedVersions, reason, attributes)
}
}
static class File {
final String name
final String url
final long size
final HashValue sha1
final HashValue md5
File(String name, String url, long size, HashValue sha1, HashValue md5) {
this.name = name
this.url = url
this.size = size
this.sha1 = sha1
this.md5 = md5
}
String toString() {
"name($name) URL($url) size($size) sha1($sha1) md5($md5)"
}
}
@Canonical
static class Capability {
String group
String name
String version
Capability(String group, String name, String version) {
this.group = group
this.name = name
this.version = version
}
}
}