org.gradle.api.publish.maven.MavenPublishHttpIntegTest.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2012 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.api.publish.maven
import org.gradle.api.artifacts.repositories.PasswordCredentials
import org.gradle.internal.credentials.DefaultPasswordCredentials
import org.gradle.integtests.fixtures.publish.maven.AbstractMavenPublishIntegTest
import org.gradle.test.fixtures.server.http.AuthScheme
import org.gradle.test.fixtures.server.http.HttpServer
import org.gradle.test.fixtures.server.http.MavenHttpModule
import org.gradle.test.fixtures.server.http.MavenHttpRepository
import org.junit.Rule
import spock.lang.Issue
import spock.lang.Unroll
class MavenPublishHttpIntegTest extends AbstractMavenPublishIntegTest {
@Rule
HttpServer server
@Rule
HttpServer redirectServer
MavenHttpRepository mavenRemoteRepo
MavenHttpModule module
def repoPath = "/repo"
String group
String name
String version
def setup() {
server.start()
mavenRemoteRepo = new MavenHttpRepository(server, repoPath, mavenRepo)
group = "org.gradle"
name = "publish"
version = "2"
module = mavenRemoteRepo.module(group, name, version)
settingsFile << 'rootProject.name = "publish"'
}
def "can publish to an unauthenticated http repo"() {
given:
buildFile << publicationBuild(version, group, mavenRemoteRepo.uri)
expectModulePublish(module)
when:
succeeds 'publish'
then:
def localPom = file("build/publications/maven/pom-default.xml").assertIsFile()
def localArtifact = file("build/libs/publish-2.jar").assertIsFile()
module.pomFile.assertIsCopyOf(localPom)
module.pom.verifyChecksums()
module.artifactFile.assertIsCopyOf(localArtifact)
module.artifact.verifyChecksums()
module.rootMetaData.verifyChecksums()
module.rootMetaData.versions == ["2"]
module.moduleMetadata.verifyChecksums()
}
@Unroll
def "can publish to authenticated repository using #authScheme auth"() {
given:
PasswordCredentials credentials = new DefaultPasswordCredentials('username', 'password')
buildFile << publicationBuild(version, group, mavenRemoteRepo.uri, credentials)
server.authenticationScheme = authScheme
module.artifact.expectPut(credentials)
module.artifact.sha1.expectPut(credentials)
module.artifact.md5.expectPut(credentials)
module.rootMetaData.expectGetMissing(credentials)
module.rootMetaData.expectPut(credentials)
module.rootMetaData.sha1.expectPut(credentials)
module.rootMetaData.md5.expectPut(credentials)
module.pom.expectPut(credentials)
module.pom.sha1.expectPut(credentials)
module.pom.md5.expectPut(credentials)
module.moduleMetadata.expectPut(credentials)
module.moduleMetadata.sha1.expectPut(credentials)
module.moduleMetadata.md5.expectPut(credentials)
when:
succeeds 'publish'
then:
def localPom = file("build/publications/maven/pom-default.xml").assertIsFile()
def localArtifact = file("build/libs/publish-2.jar").assertIsFile()
module.pomFile.assertIsCopyOf(localPom)
module.pom.verifyChecksums()
module.artifactFile.assertIsCopyOf(localArtifact)
module.artifact.verifyChecksums()
module.moduleMetadata.verifyChecksums()
module.rootMetaData.verifyChecksums()
module.rootMetaData.versions == ["2"]
where:
authScheme << [AuthScheme.BASIC, AuthScheme.DIGEST, AuthScheme.NTLM]
}
@Unroll
def "reports failure publishing with wrong credentials using #authScheme"() {
given:
PasswordCredentials credentials = new DefaultPasswordCredentials('wrong', 'wrong')
buildFile << publicationBuild(version, group, mavenRemoteRepo.uri, credentials)
server.authenticationScheme = authScheme
module.artifact.expectPut(401, credentials)
module.pom.expectPut(401, credentials)
module.moduleMetadata.expectPut(401, credentials)
when:
fails 'publish'
then:
failure.assertHasDescription("Execution failed for task ':publishMavenPublicationToMavenRepository'.")
failure.assertHasCause("Failed to publish publication 'maven' to repository 'maven'")
failure.assertHasCause("Could not write to resource '${module.artifact.uri}")
failure.assertHasCause("Could not PUT '${module.artifact.uri}'. Received status code 401 from server: Unauthorized")
where:
authScheme << [AuthScheme.BASIC, AuthScheme.DIGEST, AuthScheme.NTLM]
}
@Unroll
def "reports failure when required credentials are not provided #authScheme"() {
given:
buildFile << publicationBuild(version, group, mavenRemoteRepo.uri)
server.authenticationScheme = authScheme
module.artifact.expectPut(401)
module.pom.expectPut(401)
module.moduleMetadata.expectPut(401)
when:
fails 'publish'
then:
failure.assertHasDescription("Execution failed for task ':publishMavenPublicationToMavenRepository'.")
failure.assertHasCause("Failed to publish publication 'maven' to repository 'maven'")
failure.assertHasCause("Could not write to resource '${module.artifact.uri}")
failure.assertHasCause("Could not PUT '${module.artifact.uri}'. Received status code 401 from server: Unauthorized")
where:
authScheme << [AuthScheme.BASIC, AuthScheme.DIGEST, AuthScheme.NTLM]
}
@Issue("GRADLE-3312")
def "can publish to a http repo via redirects"() {
given:
buildFile << publicationBuild(version, group, mavenRemoteRepo.uri)
redirectServer.start()
buildFile.text = publicationBuild(version, group, new URI("${redirectServer.uri}/repo"))
redirectServer.expectGetRedirected(module.rootMetaData.path, "${server.uri}${module.rootMetaData.path}")
module.rootMetaData.expectGetMissing()
expectModulePublishViaRedirect(module, server.getUri(), redirectServer)
when:
succeeds 'publish'
then:
def localPom = file("build/publications/maven/pom-default.xml").assertIsFile()
def localArtifact = file("build/libs/publish-2.jar").assertIsFile()
module.pomFile.assertIsCopyOf(localPom)
module.pom.verifyChecksums()
module.artifactFile.assertIsCopyOf(localArtifact)
module.artifact.verifyChecksums()
module.rootMetaData.verifyChecksums()
module.rootMetaData.versions == ["2"]
}
@Issue("GRADLE-3312")
def "can publish to an authenticated http repo via redirects"() {
given:
redirectServer.start()
PasswordCredentials credentials = new DefaultPasswordCredentials('username', 'password')
buildFile.text = publicationBuild(version, group, new URI("${redirectServer.uri}/repo"), credentials)
redirectServer.expectGetRedirected(module.rootMetaData.path, "${server.uri}${module.rootMetaData.path}")
module.rootMetaData.expectGetMissing(credentials)
expectModulePublishViaRedirect(module, server.getUri(), redirectServer, credentials)
when:
succeeds 'publish'
then:
def localPom = file("build/publications/maven/pom-default.xml").assertIsFile()
def localArtifact = file("build/libs/publish-2.jar").assertIsFile()
module.pomFile.assertIsCopyOf(localPom)
module.pom.verifyChecksums()
module.artifactFile.assertIsCopyOf(localArtifact)
module.artifact.verifyChecksums()
module.rootMetaData.verifyChecksums()
module.rootMetaData.versions == ["2"]
}
@Issue("gradle/gradle#1641")
def "can publish a new version of a module already present in the target repository"() {
given:
buildFile << publicationBuild(version, group, mavenRemoteRepo.uri)
expectModulePublish(module)
when:
succeeds 'publish'
and:
buildFile.text = publicationBuild("3", group, mavenRemoteRepo.uri)
module = mavenRemoteRepo.module(group, name, "3")
then:
module.artifact.expectPublish()
module.pom.expectPublish()
module.moduleMetadata.expectPublish()
and:
module.rootMetaData.expectGet()
module.rootMetaData.sha1.expectGet()
module.rootMetaData.expectGet()
module.rootMetaData.sha1.expectGet()
module.rootMetaData.expectPublish()
and:
succeeds 'publish'
then:
def localPom = file("build/publications/maven/pom-default.xml").assertIsFile()
def localArtifact3 = file("build/libs/publish-3.jar").assertIsFile()
module.pomFile.assertIsCopyOf(localPom)
module.pom.verifyChecksums()
module.artifactFile.assertIsCopyOf(localArtifact3)
module.artifact.verifyChecksums()
module.moduleMetadata.verifyChecksums()
module.rootMetaData.verifyChecksums()
module.rootMetaData.versions == ["2", "3"]
}
private String publicationBuild(String version, String group, URI uri, PasswordCredentials credentials = null) {
String credentialsBlock = credentials ? """
credentials{
username '${credentials.username}'
password '${credentials.password}'
}
""" : ''
return """
apply plugin: 'java'
apply plugin: 'maven-publish'
version = '$version'
group = '$group'
publishing {
repositories {
maven {
url "$uri"
${credentialsBlock}
}
}
publications {
maven(MavenPublication) {
from components.java
}
}
}
"""
}
private void expectModulePublish(MavenHttpModule module) {
module.artifact.expectPublish()
module.rootMetaData.expectGetMissing()
module.rootMetaData.expectPublish()
module.pom.expectPublish()
module.moduleMetadata.expectPublish()
}
private void expectModulePublishViaRedirect(MavenHttpModule module, URI targetServerUri, HttpServer httpServer, PasswordCredentials credentials = null) {
String redirectUri = targetServerUri.toString()
[module.artifact, module.pom, module.rootMetaData, module.moduleMetadata].each { artifact ->
[artifact, artifact.sha1, artifact.md5].each { innerArtifact ->
httpServer.expectPutRedirected(innerArtifact.path, "${redirectUri}${innerArtifact.path}")
innerArtifact.expectPut(credentials)
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy