2018-08-15 11:44:20 +02:00
|
|
|
package sonia.scm.it;
|
|
|
|
|
|
|
|
|
|
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-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-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-29 13:34:53 +02:00
|
|
|
import static org.assertj.core.api.Assertions.assertThat;
|
2018-08-17 09:33:45 +02:00
|
|
|
import static java.lang.Thread.sleep;
|
|
|
|
|
import static org.hamcrest.Matchers.equalTo;
|
2018-08-15 11:44:20 +02:00
|
|
|
import static org.junit.Assert.assertNotNull;
|
|
|
|
|
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
|
|
|
|
|
|
|
|
@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
|
|
|
|