Dongsu, KIM
2013-01-04 eccc636cc0186c75da04e546a65ea0f977ac5bd3
tests/com/gitblit/tests/GitServletTest.java
@@ -88,6 +88,11 @@
   @Test
   public void testClone() throws Exception {
      GitBlitSuite.close(ticgitFolder);
      if (ticgitFolder.exists()) {
         FileUtils.delete(ticgitFolder, FileUtils.RECURSIVE | FileUtils.RETRY);
      }
      CloneCommand clone = Git.cloneRepository();
      clone.setURI(MessageFormat.format("{0}/git/ticgit.git", url));
      clone.setDirectory(ticgitFolder);
@@ -187,6 +192,20 @@
   @Test
   public void testAnonymousPush() throws Exception {
      GitBlitSuite.close(ticgitFolder);
      if (ticgitFolder.exists()) {
         FileUtils.delete(ticgitFolder, FileUtils.RECURSIVE | FileUtils.RETRY);
      }
      CloneCommand clone = Git.cloneRepository();
      clone.setURI(MessageFormat.format("{0}/git/ticgit.git", url));
      clone.setDirectory(ticgitFolder);
      clone.setBare(false);
      clone.setCloneAllBranches(true);
      clone.setCredentialsProvider(new UsernamePasswordCredentialsProvider(account, password));
      GitBlitSuite.close(clone.call());
      assertTrue(true);
      Git git = Git.open(ticgitFolder);
      File file = new File(ticgitFolder, "TODO");
      OutputStreamWriter os = new OutputStreamWriter(new FileOutputStream(file, true), Constants.CHARSET);
@@ -201,6 +220,11 @@
   @Test
   public void testSubfolderPush() throws Exception {
      GitBlitSuite.close(jgitFolder);
      if (jgitFolder.exists()) {
         FileUtils.delete(jgitFolder, FileUtils.RECURSIVE | FileUtils.RETRY);
      }
      CloneCommand clone = Git.cloneRepository();
      clone.setURI(MessageFormat.format("{0}/git/test/jgit.git", url));
      clone.setDirectory(jgitFolder);
@@ -218,6 +242,51 @@
      w.close();
      git.add().addFilepattern(file.getName()).call();
      git.commit().setMessage("test commit").call();
      git.push().setPushAll().call();
      GitBlitSuite.close(git);
   }
   @Test
   public void testPushToFrozenRepo() throws Exception {
      GitBlitSuite.close(jgitFolder);
      if (jgitFolder.exists()) {
         FileUtils.delete(jgitFolder, FileUtils.RECURSIVE | FileUtils.RETRY);
      }
      CloneCommand clone = Git.cloneRepository();
      clone.setURI(MessageFormat.format("{0}/git/test/jgit.git", url));
      clone.setDirectory(jgitFolder);
      clone.setBare(false);
      clone.setCloneAllBranches(true);
      clone.setCredentialsProvider(new UsernamePasswordCredentialsProvider(account, password));
      GitBlitSuite.close(clone.call());
      assertTrue(true);
      // freeze repo
      RepositoryModel model = GitBlit.self().getRepositoryModel("test/jgit.git");
      model.isFrozen = true;
      GitBlit.self().updateRepositoryModel(model.name, model, false);
      Git git = Git.open(jgitFolder);
      File file = new File(jgitFolder, "TODO");
      OutputStreamWriter os = new OutputStreamWriter(new FileOutputStream(file, true), Constants.CHARSET);
      BufferedWriter w = new BufferedWriter(os);
      w.write("// " + new Date().toString() + "\n");
      w.close();
      git.add().addFilepattern(file.getName()).call();
      git.commit().setMessage("test commit").call();
      try {
         git.push().setPushAll().call();
         assertTrue(false);
      } catch (Exception e) {
         assertTrue(e.getCause().getMessage().contains("access forbidden"));
      }
      // unfreeze repo
      model.isFrozen = false;
      GitBlit.self().updateRepositoryModel(model.name, model, false);
      git.push().setPushAll().call();
      GitBlitSuite.close(git);
   }
@@ -611,11 +680,13 @@
      }
      
      File personalRepo = new File(GitBlitSuite.REPOSITORIES, MessageFormat.format("~{0}/ticgit.git", user.username));
      GitBlitSuite.close(personalRepo);
      if (personalRepo.exists()) {
         FileUtils.delete(personalRepo, FileUtils.RECURSIVE);
      }
      File projectRepo = new File(GitBlitSuite.REPOSITORIES, "project/ticgit.git");
      GitBlitSuite.close(projectRepo);
      if (projectRepo.exists()) {
         FileUtils.delete(projectRepo, FileUtils.RECURSIVE);
      }
@@ -628,6 +699,8 @@
      clone.setCredentialsProvider(cp);
      Git git = clone.call();
      
      GitBlitSuite.close(personalRepo);
      // add a personal repository remote and a project remote
      git.getRepository().getConfig().setString("remote", "user", "url", MessageFormat.format("{0}/git/~{1}/ticgit.git", url, user.username));
      git.getRepository().getConfig().setString("remote", "project", "url", MessageFormat.format("{0}/git/project/ticgit.git", url));