Package org.eclipse.jgit.transport.RemoteRefUpdate

Examples of org.eclipse.jgit.transport.RemoteRefUpdate.Status


        rru.setStatus(Status.OK);
  }

  private void updateTrackingRefs() {
    for (final RemoteRefUpdate rru : toPush.values()) {
      final Status status = rru.getStatus();
      if (rru.hasTrackingRefUpdate()
          && (status == Status.UP_TO_DATE || status == Status.OK)) {
        // update local tracking branch only when there is a chance that
        // it has changed; this is possible for:
        // -updated (OK) status,
View Full Code Here


      }
    }

    for (PushResult result : results) {
      RemoteRefUpdate ref = result.getRemoteUpdate("refs/heads/master");
      Status status = ref.getStatus();
      if (permission.atLeast(AccessPermission.PUSH)) {
        assertTrue("User failed to push commit?! " + status.name(), Status.OK.equals(status));
      } else {
        // close serving repository
        GitBlitSuite.close(refChecks);

        assertTrue("User was able to push commit! " + status.name(), Status.REJECTED_OTHER_REASON.equals(status));
        GitBlitSuite.close(git);
        // skip delete test
        return;
      }
    }

    // create a local branch and push the new branch back to the origin
    git.branchCreate().setName("protectme").call();
    RefSpec refSpec = new RefSpec("refs/heads/protectme:refs/heads/protectme");
    results = git.push().setCredentialsProvider(cp).setRefSpecs(refSpec).setRemote("origin").call();
    for (PushResult result : results) {
      RemoteRefUpdate ref = result.getRemoteUpdate("refs/heads/protectme");
      Status status = ref.getStatus();
      if (Status.OK.equals(expectedCreate)) {
        assertTrue("User failed to push creation?! " + status.name(), status.equals(expectedCreate));
      } else {
        // close serving repository
        GitBlitSuite.close(refChecks);

        assertTrue("User was able to push ref creation! " + status.name(), status.equals(expectedCreate));
        GitBlitSuite.close(git);
        // skip delete test
        return;
      }
    }

    // delete the branch locally
    git.branchDelete().setBranchNames("protectme").call();

    // push a delete ref command
    refSpec = new RefSpec(":refs/heads/protectme");
    results = git.push().setCredentialsProvider(cp).setRefSpecs(refSpec).setRemote("origin").call();
    for (PushResult result : results) {
      RemoteRefUpdate ref = result.getRemoteUpdate("refs/heads/protectme");
      Status status = ref.getStatus();
      if (Status.OK.equals(expectedDelete)) {
        assertTrue("User failed to push ref deletion?! " + status.name(), status.equals(Status.OK));
      } else {
        // close serving repository
        GitBlitSuite.close(refChecks);

        assertTrue("User was able to push ref deletion?! " + status.name(), status.equals(expectedDelete));
        GitBlitSuite.close(git);
        // skip rewind test
        return;
      }
    }

    // rewind master by two commits
    git.reset().setRef("HEAD~2").setMode(ResetType.HARD).call();

    // commit a change on this detached HEAD
    file = new File(local, "REWINDCHK");
    os = new OutputStreamWriter(new FileOutputStream(file, true), Constants.CHARSET);
    w = new BufferedWriter(os);
    w.write("// " + new Date().toString() + "\n");
    w.close();
    git.add().addFilepattern(file.getName()).call();
    RevCommit commit = git.commit().setMessage("rewind master and new commit").call();

    // Reset master to our new commit now we our local branch tip is no longer
    // upstream of the remote branch tip.  It is an alternate tip of the branch.
    JGitUtils.setBranchRef(git.getRepository(), "refs/heads/master", commit.getName());

    // Try pushing our new tip to the origin.
    // This requires the server to "rewind" it's master branch and update it
    // to point to our alternate tip.  This leaves the original master tip
    // unreferenced.
    results = git.push().setCredentialsProvider(cp).setRemote("origin").setForce(true).call();
    for (PushResult result : results) {
      RemoteRefUpdate ref = result.getRemoteUpdate("refs/heads/master");
      Status status = ref.getStatus();
      if (Status.OK.equals(expectedRewind)) {
        assertTrue("User failed to rewind master?! " + status.name(), status.equals(expectedRewind));
      } else {
        assertTrue("User was able to rewind master?! " + status.name(), status.equals(expectedRewind));
      }
    }
    GitBlitSuite.close(git);

    // close serving repository
View Full Code Here

    try {
      Iterable<PushResult> results = git.push().setRemote("user").setPushAll().setCredentialsProvider(cp).call();

      for (PushResult result : results) {
        RemoteRefUpdate ref = result.getRemoteUpdate("refs/heads/master");
        Status status = ref.getStatus();
        assertTrue("User failed to create repository?! " + status.name(), Status.OK.equals(status));
      }

      assertTrue("User canAdmin:" + user.canAdmin + " canCreate:" + user.canCreate, user.canAdmin || user.canCreate);

      // confirm default personal repository permissions
      RepositoryModel model = repositories().getRepositoryModel(MessageFormat.format("~{0}/ticgit.git", user.username));
      assertEquals("Unexpected owner", user.username, ArrayUtils.toString(model.owners));
      assertEquals("Unexpected authorization control", AuthorizationControl.NAMED, model.authorizationControl);
      assertEquals("Unexpected access restriction", AccessRestrictionType.VIEW, model.accessRestriction);

    } catch (GitAPIException e) {
      assertTrue(e.getMessage(), e.getMessage().contains("git-receive-pack not found"));
      assertFalse("User canAdmin:" + user.canAdmin + " canCreate:" + user.canCreate, user.canAdmin || user.canCreate);
    }

    // push to non-existent project repository
    try {
      Iterable<PushResult> results = git.push().setRemote("project").setPushAll().setCredentialsProvider(cp).call();
      GitBlitSuite.close(git);

      for (PushResult result : results) {
        RemoteRefUpdate ref = result.getRemoteUpdate("refs/heads/master");
        Status status = ref.getStatus();
        assertTrue("User failed to create repository?! " + status.name(), Status.OK.equals(status));
      }

      assertTrue("User canAdmin:" + user.canAdmin, user.canAdmin);

      // confirm default project repository permissions
View Full Code Here

    git.commit().setMessage("push test").call();
    Iterable<PushResult> results = git.push().setCredentialsProvider(cp).setRemote("origin").call();

    for (PushResult result : results) {
      RemoteRefUpdate ref = result.getRemoteUpdate("refs/heads/master");
      Status status = ref.getStatus();
      if (expectedSuccess) {
        assertTrue("Verification failed! User was NOT able to push commit! " + status.name(), Status.OK.equals(status));
      } else {
        assertTrue("Verification failed! User was able to push commit! " + status.name(), Status.REJECTED_OTHER_REASON.equals(status));
      }
    }

    GitBlitSuite.close(git);
    // close serving repository
View Full Code Here

    // push the merged master to the origin
    Iterable<PushResult> results = git.push().setCredentialsProvider(cp).setRemote("origin").call();

    for (PushResult result : results) {
      RemoteRefUpdate ref = result.getRemoteUpdate("refs/heads/master");
      Status status = ref.getStatus();
      if (expectedSuccess) {
        assertTrue("Verification failed! User was NOT able to push commit! " + status.name(), Status.OK.equals(status));
      } else {
        assertTrue("Verification failed! User was able to push commit! " + status.name(), Status.REJECTED_OTHER_REASON.equals(status));
      }
    }

    GitBlitSuite.close(git);
    // close serving repository
View Full Code Here

        rru.setStatus(Status.OK);
  }

  private void updateTrackingRefs() {
    for (final RemoteRefUpdate rru : toPush.values()) {
      final Status status = rru.getStatus();
      if (rru.hasTrackingRefUpdate()
          && (status == Status.UP_TO_DATE || status == Status.OK)) {
        // update local tracking branch only when there is a chance that
        // it has changed; this is possible for:
        // -updated (OK) status,
View Full Code Here

    assertEquals("Error", jo.get("Severity"));

    JSONArray up = (JSONArray) jo.get("Updates");
    assertEquals(1, up.length());

    Status pushResult = Status.valueOf((String) ((JSONObject) up.get(0)).get("Result"));
    assertEquals(Status.REJECTED_NONFASTFORWARD, pushResult);
  }
View Full Code Here

    JSONArray up = (JSONArray) jo.get("Updates");
    assertEquals(1, up.length());

    assertEquals("Error", jo.get("Severity"));
    Status pushResult = Status.valueOf((String) ((JSONObject) up.get(0)).get("Result"));
    assertEquals(Status.REJECTED_OTHER_REASON, pushResult);

    assertTrue(((JSONObject) up.get(0)).getString("Message"), ((JSONObject) up.get(0)).getString("Message").matches("^object [\\da-f]+ missing$"));
  }
View Full Code Here

      JSONArray up = (JSONArray) jo.get("Updates");
      assertEquals(1, up.length());

      assertEquals("Error", jo.get("Severity"));
      Status pushResult = Status.valueOf((String) ((JSONObject) up.get(0)).get("Result"));
      assertEquals(Status.REJECTED_NONFASTFORWARD, pushResult);

      // clone2: forced push
      pushStatus = push(gitRemoteUri2, 1, 0, Constants.MASTER, Constants.HEAD, false, true);
      jo = pushStatus.getJsonData();
View Full Code Here

      JSONArray up = (JSONArray) jo.get("Updates");
      assertEquals(1, up.length());

      assertEquals("Error", jo.get("Severity"));
      Status pushResult = Status.valueOf((String) ((JSONObject) up.get(0)).get("Result"));
      assertEquals(Status.REJECTED_NONFASTFORWARD, pushResult);

      // clone2: forced push
      pushStatus = push(gitRemoteUri2, 1, 0, Constants.MASTER, Constants.HEAD, false, true);
      jo = pushStatus.getJsonData();
View Full Code Here

TOP

Related Classes of org.eclipse.jgit.transport.RemoteRefUpdate.Status

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.