2018-08-15 11:44:20 +02:00
|
|
|
package sonia.scm.it;
|
|
|
|
|
|
2018-09-04 17:38:28 +02:00
|
|
|
import io.restassured.response.ExtractableResponse;
|
|
|
|
|
import io.restassured.response.Response;
|
2018-08-15 11:44:20 +02:00
|
|
|
import org.apache.http.HttpStatus;
|
2018-08-24 07:57:13 +02:00
|
|
|
import org.junit.Assume;
|
2018-08-15 11:44:20 +02:00
|
|
|
import org.junit.Before;
|
|
|
|
|
import org.junit.Rule;
|
|
|
|
|
import org.junit.Test;
|
|
|
|
|
import org.junit.rules.TemporaryFolder;
|
|
|
|
|
import org.junit.runner.RunWith;
|
|
|
|
|
import org.junit.runners.Parameterized;
|
2018-09-04 17:38:28 +02:00
|
|
|
import sonia.scm.repository.Changeset;
|
2018-08-24 07:57:13 +02:00
|
|
|
import sonia.scm.repository.client.api.ClientCommand;
|
2018-08-22 09:18:17 +02:00
|
|
|
import sonia.scm.repository.client.api.RepositoryClient;
|
2018-09-04 17:38:28 +02:00
|
|
|
import sonia.scm.web.VndMediaType;
|
2018-08-15 11:44:20 +02:00
|
|
|
|
2018-08-22 09:18:17 +02:00
|
|
|
import java.io.File;
|
2018-08-15 11:44:20 +02:00
|
|
|
import java.io.IOException;
|
|
|
|
|
import java.util.Collection;
|
2018-08-29 13:34:53 +02:00
|
|
|
import java.util.List;
|
2018-08-15 11:44:20 +02:00
|
|
|
|
2018-08-17 09:33:45 +02:00
|
|
|
import static java.lang.Thread.sleep;
|
2018-09-04 17:38:28 +02:00
|
|
|
import static org.assertj.core.api.Assertions.assertThat;
|
2018-08-17 09:33:45 +02:00
|
|
|
import static org.hamcrest.Matchers.equalTo;
|
2018-08-15 11:44:20 +02:00
|
|
|
import static org.junit.Assert.assertNotNull;
|
2018-09-04 17:38:28 +02:00
|
|
|
import static sonia.scm.it.RestUtil.ADMIN_PASSWORD;
|
|
|
|
|
import static sonia.scm.it.RestUtil.ADMIN_USERNAME;
|
2018-08-15 11:44:20 +02:00
|
|
|
import static sonia.scm.it.RestUtil.given;
|
|
|
|
|
import static sonia.scm.it.ScmTypes.availableScmTypes;
|
|
|
|
|
|
|
|
|
|
@RunWith(Parameterized.class)
|
|
|
|
|
public class RepositoryAccessITCase {
|
|
|
|
|
|
|
|
|
|
@Rule
|
|
|
|
|
public TemporaryFolder tempFolder = new TemporaryFolder();
|
|
|
|
|
|
|
|
|
|
private final String repositoryType;
|
2018-08-22 09:18:17 +02:00
|
|
|
private File folder;
|
2018-08-15 11:44:20 +02:00
|
|
|
|
|
|
|
|
public RepositoryAccessITCase(String repositoryType) {
|
|
|
|
|
this.repositoryType = repositoryType;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Parameterized.Parameters(name = "{0}")
|
|
|
|
|
public static Collection<String> createParameters() {
|
|
|
|
|
return availableScmTypes();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Before
|
2018-08-22 09:18:17 +02:00
|
|
|
public void initClient() {
|
2018-08-15 11:44:20 +02:00
|
|
|
TestData.createDefault();
|
2018-08-22 09:18:17 +02:00
|
|
|
folder = tempFolder.getRoot();
|
2018-08-15 11:44:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void shouldFindBranches() throws IOException {
|
2018-08-22 10:59:46 +02:00
|
|
|
RepositoryClient repositoryClient = RepositoryUtil.createRepositoryClient(repositoryType, folder);
|
2018-08-15 11:44:20 +02:00
|
|
|
|
2018-08-24 07:57:13 +02:00
|
|
|
Assume.assumeTrue("There are no branches for " + repositoryType, repositoryClient.isCommandSupported(ClientCommand.BRANCH));
|
|
|
|
|
|
2018-08-22 10:59:46 +02:00
|
|
|
RepositoryUtil.createAndCommitFile(repositoryClient, "scmadmin", "a.txt", "a");
|
2018-08-15 11:44:20 +02:00
|
|
|
|
|
|
|
|
String branchesUrl = given()
|
|
|
|
|
.when()
|
|
|
|
|
.get(TestData.getDefaultRepositoryUrl(repositoryType))
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
|
|
|
|
.path("_links.branches.href");
|
|
|
|
|
|
|
|
|
|
Object branchName = given()
|
|
|
|
|
.when()
|
|
|
|
|
.get(branchesUrl)
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
|
|
|
|
.path("_embedded.branches[0].name");
|
|
|
|
|
|
|
|
|
|
assertNotNull(branchName);
|
|
|
|
|
}
|
2018-08-17 09:33:45 +02:00
|
|
|
|
2018-09-04 17:38:28 +02:00
|
|
|
@Test
|
|
|
|
|
public void shouldFindTags() throws IOException {
|
|
|
|
|
RepositoryClient repositoryClient = RepositoryUtil.createRepositoryClient(repositoryType, folder);
|
|
|
|
|
|
|
|
|
|
Assume.assumeTrue("There are no tags for " + repositoryType, repositoryClient.isCommandSupported(ClientCommand.TAG));
|
|
|
|
|
|
|
|
|
|
Changeset changeset = RepositoryUtil.createAndCommitFile(repositoryClient, ADMIN_USERNAME, "a.txt", "a");
|
|
|
|
|
|
|
|
|
|
String tagName = "v1.0";
|
|
|
|
|
String repositoryUrl = TestData.getDefaultRepositoryUrl(repositoryType);
|
|
|
|
|
String tagsUrl = given()
|
|
|
|
|
.when()
|
|
|
|
|
.get(repositoryUrl)
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
|
|
|
|
.path("_links.tags.href");
|
|
|
|
|
|
|
|
|
|
ExtractableResponse<Response> response = given(VndMediaType.TAG_COLLECTION, ADMIN_USERNAME, ADMIN_PASSWORD)
|
|
|
|
|
.when()
|
|
|
|
|
.get(tagsUrl)
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract();
|
|
|
|
|
|
|
|
|
|
assertThat(response).isNotNull();
|
|
|
|
|
assertThat(response.body()).isNotNull();
|
|
|
|
|
assertThat(response.body().asString())
|
|
|
|
|
.isNotNull()
|
|
|
|
|
.isNotBlank()
|
|
|
|
|
;
|
|
|
|
|
|
|
|
|
|
RepositoryUtil.addTag(repositoryClient, changeset.getId(), tagName);
|
|
|
|
|
response = given(VndMediaType.TAG_COLLECTION, ADMIN_USERNAME, ADMIN_PASSWORD)
|
|
|
|
|
.when()
|
|
|
|
|
.get(tagsUrl)
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
|
|
|
|
;
|
|
|
|
|
|
|
|
|
|
assertThat(response).isNotNull();
|
|
|
|
|
assertThat(response.body()).isNotNull();
|
|
|
|
|
assertThat(response.body().asString())
|
|
|
|
|
.isNotNull()
|
|
|
|
|
.isNotBlank()
|
|
|
|
|
;
|
|
|
|
|
assertThat(response.body().jsonPath().getString("_links.self.href"))
|
|
|
|
|
.as("assert tags self link")
|
|
|
|
|
.isNotNull()
|
|
|
|
|
.contains(repositoryUrl + "/tags/")
|
|
|
|
|
;
|
|
|
|
|
assertThat(response.body().jsonPath().getList("_embedded.tags"))
|
|
|
|
|
.as("assert tag size")
|
|
|
|
|
.isNotNull()
|
|
|
|
|
.size()
|
|
|
|
|
.isGreaterThan(0)
|
|
|
|
|
;
|
|
|
|
|
assertThat(response.body().jsonPath().getMap("_embedded.tags.find{it.name=='" + tagName + "'}"))
|
|
|
|
|
.as("assert tag name and revision")
|
|
|
|
|
.isNotNull()
|
|
|
|
|
.hasSize(3)
|
|
|
|
|
.containsEntry("name", tagName)
|
|
|
|
|
.containsEntry("revision", changeset.getId())
|
|
|
|
|
;
|
|
|
|
|
assertThat(response.body().jsonPath().getString("_embedded.tags.find{it.name=='" + tagName + "'}._links.self.href"))
|
|
|
|
|
.as("assert single tag self link")
|
|
|
|
|
.isNotNull()
|
|
|
|
|
.contains(String.format("%s/tags/%s", repositoryUrl, tagName))
|
|
|
|
|
;
|
|
|
|
|
assertThat(response.body().jsonPath().getString("_embedded.tags.find{it.name=='" + tagName + "'}._links.sources.href"))
|
|
|
|
|
.as("assert single tag source link")
|
|
|
|
|
.isNotNull()
|
|
|
|
|
.contains(String.format("%s/sources/%s", repositoryUrl, changeset.getId()))
|
|
|
|
|
;
|
|
|
|
|
assertThat(response.body().jsonPath().getString("_embedded.tags.find{it.name=='" + tagName + "'}._links.changesets.href"))
|
|
|
|
|
.as("assert single tag changesets link")
|
|
|
|
|
.isNotNull()
|
|
|
|
|
.contains(String.format("%s/changesets/%s", repositoryUrl, changeset.getId()))
|
|
|
|
|
;
|
|
|
|
|
}
|
|
|
|
|
|
2018-08-17 09:33:45 +02:00
|
|
|
@Test
|
|
|
|
|
public void shouldReadContent() throws IOException, InterruptedException {
|
2018-08-28 12:43:56 +02:00
|
|
|
RepositoryClient repositoryClient = RepositoryUtil.createRepositoryClient(repositoryType, folder);
|
|
|
|
|
RepositoryUtil.createAndCommitFile(repositoryClient, "scmadmin", "a.txt", "a");
|
2018-08-23 15:52:02 +02:00
|
|
|
tempFolder.newFolder("subfolder");
|
2018-08-28 12:43:56 +02:00
|
|
|
RepositoryUtil.createAndCommitFile(repositoryClient, "scmadmin", "subfolder/a.txt", "sub-a");
|
2018-08-17 09:33:45 +02:00
|
|
|
|
|
|
|
|
sleep(1000);
|
|
|
|
|
|
|
|
|
|
String sourcesUrl = given()
|
|
|
|
|
.when()
|
|
|
|
|
.get(TestData.getDefaultRepositoryUrl(repositoryType))
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
|
|
|
|
.path("_links.sources.href");
|
|
|
|
|
|
2018-08-23 15:52:02 +02:00
|
|
|
String rootContentUrl = given()
|
2018-08-17 09:33:45 +02:00
|
|
|
.when()
|
|
|
|
|
.get(sourcesUrl)
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
2018-08-24 09:15:15 +02:00
|
|
|
.path("files.find{it.name=='a.txt'}._links.self.href");
|
2018-08-17 09:33:45 +02:00
|
|
|
given()
|
|
|
|
|
.when()
|
2018-08-23 15:52:02 +02:00
|
|
|
.get(rootContentUrl)
|
2018-08-17 09:33:45 +02:00
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.body(equalTo("a"));
|
2018-08-23 15:52:02 +02:00
|
|
|
|
|
|
|
|
String subfolderSourceUrl = given()
|
|
|
|
|
.when()
|
|
|
|
|
.get(sourcesUrl)
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
|
|
|
|
.path("files.find{it.name=='subfolder'}._links.self.href");
|
|
|
|
|
String subfolderContentUrl= given()
|
|
|
|
|
.when()
|
|
|
|
|
.get(subfolderSourceUrl)
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
2018-08-24 09:15:15 +02:00
|
|
|
.path("files[0]._links.self.href");
|
2018-08-23 15:52:02 +02:00
|
|
|
given()
|
|
|
|
|
.when()
|
|
|
|
|
.get(subfolderContentUrl)
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.body(equalTo("sub-a"));
|
2018-08-17 09:33:45 +02:00
|
|
|
}
|
2018-08-29 13:34:53 +02:00
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void shouldFindChangesets() throws IOException {
|
|
|
|
|
RepositoryClient repositoryClient = RepositoryUtil.createRepositoryClient(repositoryType, folder);
|
|
|
|
|
|
|
|
|
|
RepositoryUtil.createAndCommitFile(repositoryClient, "scmadmin", "a.txt", "a");
|
|
|
|
|
RepositoryUtil.createAndCommitFile(repositoryClient, "scmadmin", "b.txt", "b");
|
|
|
|
|
|
|
|
|
|
String changesetsUrl = given()
|
|
|
|
|
.when()
|
|
|
|
|
.get(TestData.getDefaultRepositoryUrl(repositoryType))
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
|
|
|
|
.path("_links.changesets.href");
|
|
|
|
|
|
|
|
|
|
List changesets = given()
|
|
|
|
|
.when()
|
|
|
|
|
.get(changesetsUrl)
|
|
|
|
|
.then()
|
|
|
|
|
.statusCode(HttpStatus.SC_OK)
|
|
|
|
|
.extract()
|
|
|
|
|
.path("_embedded.changesets.id");
|
|
|
|
|
|
|
|
|
|
assertThat(changesets).size().isBetween(2, 3); // svn has an implicit root revision '0' that is extra to the two commits
|
|
|
|
|
}
|
2018-08-15 11:44:20 +02:00
|
|
|
}
|
2018-08-29 13:34:53 +02:00
|
|
|
|