Mercurial > hg > mercurial
diff mercurial-tests/src/jetbrains/buildServer/buildTriggers/vcs/mercurial/PurgeTest.java @ 834:80ae3dc66685
TW-18605 add support for 'hg purge'
author | Dmitry Neverov <dmitry.neverov@jetbrains.com> |
---|---|
date | Sun, 01 Jun 2014 22:16:18 +0200 |
parents | |
children | 58d083742bc4 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mercurial-tests/src/jetbrains/buildServer/buildTriggers/vcs/mercurial/PurgeTest.java Sun Jun 01 22:16:18 2014 +0200 @@ -0,0 +1,127 @@ +/* + * Copyright 2000-2014 JetBrains s.r.o. + * + * 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 jetbrains.buildServer.buildTriggers.vcs.mercurial; + +import jetbrains.buildServer.buildTriggers.vcs.mercurial.command.HgVcsRoot; +import jetbrains.buildServer.util.FileUtil; +import jetbrains.buildServer.vcs.VcsRoot; +import org.jetbrains.annotations.NotNull; +import org.testng.annotations.BeforeMethod; +import org.testng.annotations.Test; + +import java.io.File; +import java.io.IOException; + +import static jetbrains.buildServer.buildTriggers.vcs.mercurial.Util.copyRepository; +import static jetbrains.buildServer.buildTriggers.vcs.mercurial.VcsRootBuilder.vcsRoot; +import static org.testng.AssertJUnit.assertFalse; +import static org.testng.AssertJUnit.assertTrue; + +@Test +public class PurgeTest extends BaseAgentSideCheckoutTestCase { + + private String myRemoteRepository; + + @Override + @BeforeMethod + public void setUp() throws Exception { + super.setUp(); + + File tmp = myTempFiles.createTempDir(); + File remoteRepo = new File(tmp, "testPurge"); + copyRepository(new File("mercurial-tests/testData/testPurge"), remoteRepo); + myRemoteRepository = remoteRepo.getAbsolutePath(); + } + + + public void purge_unknown() throws Exception { + VcsRoot vcsRoot = vcsRoot().withUrl(myRemoteRepository).withPurgePolicy(HgVcsRoot.PurgePolicy.PURGE_UNKNOWN).build(); + checkout(vcsRoot, "1:80a857d1f74b"); + + File unknownFile = createUnknownFile(myWorkDir); + File ignoredFile = createIgnoredFile(myWorkDir); + + checkout(vcsRoot, "1:80a857d1f74b"); + + assertFalse(unknownFile.exists()); + assertTrue(ignoredFile.exists()); + } + + + public void purge_all() throws Exception { + VcsRoot vcsRoot = vcsRoot().withUrl(myRemoteRepository).withPurgePolicy(HgVcsRoot.PurgePolicy.PURGE_ALL).build(); + checkout(vcsRoot, "1:80a857d1f74b"); + + File unknownFile = createUnknownFile(myWorkDir); + File ignoredFile = createIgnoredFile(myWorkDir); + + checkout(vcsRoot, "1:80a857d1f74b"); + + assertFalse(unknownFile.exists()); + assertFalse(ignoredFile.exists()); + } + + + public void purge_unknown_subrepos() throws Exception { + VcsRoot vcsRoot = vcsRoot().withUrl(myRemoteRepository).withPurgePolicy(HgVcsRoot.PurgePolicy.PURGE_UNKNOWN).build(); + checkout(vcsRoot, "2:5998f41141bc"); + + File unknownFile = createUnknownFile(myWorkDir); + File ignoredFile = createIgnoredFile(myWorkDir); + File unknownFileSubrepo = createUnknownFile(new File(myWorkDir, "self")); + File ignoredFileSubrepo = createIgnoredFile(new File(myWorkDir, "self")); + + checkout(vcsRoot, "2:5998f41141bc"); + + assertFalse(unknownFile.exists()); + assertFalse(unknownFileSubrepo.exists()); + assertTrue(ignoredFile.exists()); + assertTrue(ignoredFileSubrepo.exists()); + } + + + public void purge_all_subrepos() throws Exception { + VcsRoot vcsRoot = vcsRoot().withUrl(myRemoteRepository).withPurgePolicy(HgVcsRoot.PurgePolicy.PURGE_ALL).build(); + checkout(vcsRoot, "2:5998f41141bc"); + + File unknownFile = createUnknownFile(myWorkDir); + File ignoredFile = createIgnoredFile(myWorkDir); + File unknownFileSubrepo = createUnknownFile(new File(myWorkDir, "self")); + File ignoredFileSubrepo = createIgnoredFile(new File(myWorkDir, "self")); + + checkout(vcsRoot, "2:5998f41141bc"); + + assertFalse(unknownFile.exists()); + assertFalse(unknownFileSubrepo.exists()); + assertFalse(ignoredFile.exists()); + assertFalse(ignoredFileSubrepo.exists()); + } + + + private File createUnknownFile(@NotNull File parentDir) throws IOException { + File unknownFile = new File(parentDir, "unknownFile"); + FileUtil.writeFile(unknownFile, "some data", "UTF-8"); + return unknownFile; + } + + + private File createIgnoredFile(@NotNull File parentDir) throws IOException { + File ignoredFile = new File(parentDir, "ignoredFile"); + FileUtil.writeFile(ignoredFile, "some data", "UTF-8"); + return ignoredFile; + } +}