2016-07-25 18:27:47 +02:00
|
|
|
/**
|
|
|
|
|
* Copyright (c) 2014, Sebastian Sdorra
|
|
|
|
|
* All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
|
* modification, are permitted provided that the following conditions are met:
|
|
|
|
|
*
|
|
|
|
|
* 1. Redistributions of source code must retain the above copyright notice,
|
|
|
|
|
* this list of conditions and the following disclaimer.
|
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
|
|
|
* and/or other materials provided with the distribution.
|
|
|
|
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
|
|
|
|
* contributors may be used to endorse or promote products derived from this
|
|
|
|
|
* software without specific prior written permission.
|
|
|
|
|
*
|
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
|
|
|
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
|
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
|
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
*
|
|
|
|
|
* http://bitbucket.org/sdorra/scm-manager
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
package sonia.scm.it;
|
|
|
|
|
|
|
|
|
|
import com.google.common.base.Charsets;
|
|
|
|
|
import com.google.common.collect.Lists;
|
|
|
|
|
import com.google.common.io.Files;
|
|
|
|
|
import com.sun.jersey.api.client.WebResource;
|
|
|
|
|
import org.junit.After;
|
2017-01-13 22:38:54 +01:00
|
|
|
import org.junit.Assume;
|
2016-07-25 18:27:47 +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;
|
|
|
|
|
import org.junit.runners.Parameterized.Parameters;
|
|
|
|
|
import sonia.scm.debug.DebugHookData;
|
|
|
|
|
import sonia.scm.repository.Changeset;
|
|
|
|
|
import sonia.scm.repository.Person;
|
|
|
|
|
import sonia.scm.repository.Repository;
|
|
|
|
|
import sonia.scm.repository.RepositoryTestData;
|
2017-01-13 22:38:54 +01:00
|
|
|
import sonia.scm.repository.client.api.ClientCommand;
|
2016-07-25 18:27:47 +02:00
|
|
|
import sonia.scm.repository.client.api.RepositoryClient;
|
|
|
|
|
import sonia.scm.repository.client.api.RepositoryClientFactory;
|
2016-07-26 00:16:14 +02:00
|
|
|
import sonia.scm.util.IOUtil;
|
2016-07-25 18:27:47 +02:00
|
|
|
|
2018-06-20 11:11:14 +02:00
|
|
|
import java.io.File;
|
|
|
|
|
import java.io.IOException;
|
|
|
|
|
import java.util.Collection;
|
|
|
|
|
|
|
|
|
|
import static org.hamcrest.Matchers.allOf;
|
|
|
|
|
import static org.hamcrest.Matchers.contains;
|
|
|
|
|
import static org.hamcrest.Matchers.not;
|
|
|
|
|
import static org.junit.Assert.assertNotNull;
|
|
|
|
|
import static org.junit.Assert.assertThat;
|
|
|
|
|
import static sonia.scm.it.IntegrationTestUtil.createResource;
|
|
|
|
|
import static sonia.scm.it.RepositoryITUtil.createRepository;
|
|
|
|
|
import static sonia.scm.it.RepositoryITUtil.deleteRepository;
|
|
|
|
|
|
2016-07-25 18:27:47 +02:00
|
|
|
/**
|
|
|
|
|
* Integration tests for repository hooks.
|
|
|
|
|
*
|
|
|
|
|
* @author Sebastian Sdorra
|
|
|
|
|
*/
|
|
|
|
|
@RunWith(Parameterized.class)
|
|
|
|
|
public class RepositoryHookITCase extends AbstractAdminITCaseBase
|
|
|
|
|
{
|
|
|
|
|
|
2017-01-12 19:50:39 +01:00
|
|
|
private static final long WAIT_TIME = 125;
|
|
|
|
|
|
2016-07-25 18:27:47 +02:00
|
|
|
private static final RepositoryClientFactory REPOSITORY_CLIENT_FACTORY = new RepositoryClientFactory();
|
|
|
|
|
|
|
|
|
|
@Rule
|
|
|
|
|
public TemporaryFolder tempFolder = new TemporaryFolder();
|
|
|
|
|
|
|
|
|
|
private final String repositoryType;
|
|
|
|
|
private Repository repository;
|
|
|
|
|
private File workingCopy;
|
|
|
|
|
private RepositoryClient repositoryClient;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Constructs a new instance with a repository type.
|
|
|
|
|
*
|
|
|
|
|
* @param repositoryType repository type
|
|
|
|
|
*/
|
|
|
|
|
public RepositoryHookITCase(String repositoryType)
|
|
|
|
|
{
|
|
|
|
|
this.repositoryType = repositoryType;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Creates a test repository.
|
|
|
|
|
*
|
|
|
|
|
* @throws IOException
|
|
|
|
|
*/
|
|
|
|
|
@Before
|
|
|
|
|
public void setUpTestRepository() throws IOException
|
|
|
|
|
{
|
|
|
|
|
repository = RepositoryTestData.createHeartOfGold(repositoryType);
|
|
|
|
|
repository = createRepository(client, repository);
|
|
|
|
|
workingCopy = tempFolder.newFolder();
|
|
|
|
|
repositoryClient = createRepositoryClient();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Removes the tests repository.
|
|
|
|
|
*/
|
|
|
|
|
@After
|
|
|
|
|
public void removeTestRepository()
|
|
|
|
|
{
|
|
|
|
|
deleteRepository(client, repository.getId());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Tests that the debug service has received the commit.
|
|
|
|
|
*
|
|
|
|
|
* @throws IOException
|
|
|
|
|
* @throws InterruptedException
|
|
|
|
|
*/
|
|
|
|
|
@Test
|
|
|
|
|
public void testSimpleHook() throws IOException, InterruptedException
|
|
|
|
|
{
|
2017-01-13 22:38:54 +01:00
|
|
|
// commit and push commit
|
2016-07-25 18:27:47 +02:00
|
|
|
Files.write("a", new File(workingCopy, "a.txt"), Charsets.UTF_8);
|
|
|
|
|
repositoryClient.getAddCommand().add("a.txt");
|
2017-01-13 22:38:54 +01:00
|
|
|
Changeset changeset = commit("added a");
|
2016-07-25 18:27:47 +02:00
|
|
|
|
|
|
|
|
// wait some time, because the debug hook is asnychron
|
2017-01-12 19:50:39 +01:00
|
|
|
Thread.sleep(WAIT_TIME);
|
2016-07-25 18:27:47 +02:00
|
|
|
|
|
|
|
|
// check debug servlet for pushed commit
|
|
|
|
|
WebResource wr = createResource(client, "debug/" + repository.getId() + "/post-receive/last");
|
|
|
|
|
DebugHookData data = wr.get(DebugHookData.class);
|
|
|
|
|
assertNotNull(data);
|
|
|
|
|
assertThat(data.getChangesets(), contains(changeset.getId()));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Tests that the debug service receives only new commits.
|
|
|
|
|
*
|
|
|
|
|
* @throws IOException
|
|
|
|
|
* @throws InterruptedException
|
|
|
|
|
*/
|
|
|
|
|
@Test
|
|
|
|
|
public void testOnlyNewCommit() throws IOException, InterruptedException
|
|
|
|
|
{
|
2017-01-13 22:38:54 +01:00
|
|
|
// skip test if branches are not supported by repository type
|
2018-06-20 11:11:14 +02:00
|
|
|
Assume.assumeTrue(repositoryClient.isCommandSupported(ClientCommand.BRANCH));
|
2017-01-13 22:38:54 +01:00
|
|
|
|
2016-07-25 18:27:47 +02:00
|
|
|
// push commit
|
|
|
|
|
Files.write("a", new File(workingCopy, "a.txt"), Charsets.UTF_8);
|
|
|
|
|
repositoryClient.getAddCommand().add("a.txt");
|
2017-01-13 22:38:54 +01:00
|
|
|
Changeset a = commit("added a");
|
2016-07-25 18:27:47 +02:00
|
|
|
|
2017-01-13 22:38:54 +01:00
|
|
|
// create branch
|
2016-07-25 18:27:47 +02:00
|
|
|
repositoryClient.getBranchCommand().branch("feature/added-b");
|
2017-01-13 22:38:54 +01:00
|
|
|
|
|
|
|
|
// commit and push again
|
2016-07-25 18:27:47 +02:00
|
|
|
Files.write("b", new File(workingCopy, "b.txt"), Charsets.UTF_8);
|
|
|
|
|
repositoryClient.getAddCommand().add("a.txt");
|
2017-01-13 22:38:54 +01:00
|
|
|
Changeset b = commit("added b");
|
2016-07-25 18:27:47 +02:00
|
|
|
|
|
|
|
|
// wait some time, because the debug hook is asnychron
|
2017-01-12 19:50:39 +01:00
|
|
|
Thread.sleep(WAIT_TIME);
|
2016-07-25 18:27:47 +02:00
|
|
|
|
|
|
|
|
// check debug servlet that only one commit is present
|
|
|
|
|
WebResource wr = createResource(client, "debug/" + repository.getId() + "/post-receive/last");
|
|
|
|
|
DebugHookData data = wr.get(DebugHookData.class);
|
|
|
|
|
assertNotNull(data);
|
|
|
|
|
assertThat(data.getChangesets(), allOf(
|
|
|
|
|
contains(b.getId()),
|
|
|
|
|
not(
|
|
|
|
|
contains(a.getId())
|
|
|
|
|
)
|
|
|
|
|
));
|
|
|
|
|
}
|
|
|
|
|
|
2017-01-13 22:38:54 +01:00
|
|
|
private Changeset commit(String message) throws IOException {
|
|
|
|
|
Changeset a = repositoryClient.getCommitCommand().commit(
|
2017-06-06 11:21:05 +02:00
|
|
|
new Person("scmadmin", "scmadmin@scm-manager.org"), message
|
2017-01-13 22:38:54 +01:00
|
|
|
);
|
|
|
|
|
if ( repositoryClient.isCommandSupported(ClientCommand.PUSH) ) {
|
|
|
|
|
repositoryClient.getPushCommand().push();
|
|
|
|
|
}
|
|
|
|
|
return a;
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-25 18:27:47 +02:00
|
|
|
private RepositoryClient createRepositoryClient() throws IOException
|
|
|
|
|
{
|
|
|
|
|
return REPOSITORY_CLIENT_FACTORY.create(repositoryType,
|
|
|
|
|
IntegrationTestUtil.BASE_URL + repositoryType + "/" + repository.getName(),
|
|
|
|
|
IntegrationTestUtil.ADMIN_USERNAME, IntegrationTestUtil.ADMIN_PASSWORD, workingCopy
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns repository types a test parameter.
|
|
|
|
|
*
|
|
|
|
|
* @return repository types test parameter
|
|
|
|
|
*/
|
|
|
|
|
@Parameters
|
|
|
|
|
public static Collection<String[]> createParameters()
|
|
|
|
|
{
|
|
|
|
|
Collection<String[]> params = Lists.newArrayList();
|
|
|
|
|
params.add(new String[] { "git" });
|
2017-01-13 22:38:54 +01:00
|
|
|
params.add(new String[] { "svn" });
|
|
|
|
|
if (IOUtil.search("hg") != null) {
|
2016-07-26 00:16:14 +02:00
|
|
|
params.add(new String[] { "hg" });
|
2017-01-12 19:50:39 +01:00
|
|
|
}
|
2016-07-25 18:27:47 +02:00
|
|
|
return params;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|