SubmoduleSubscription: Move common code to AbstractSubmoduleSubscription
This makes it easy to introduce another class for testing the submodule subscriptions. No changes in behavior and functionality intended. Change-Id: I45068b8cf8312bceef935048fb7f9babd8d72201
This commit is contained in:
		| @@ -0,0 +1,82 @@ | |||||||
|  | // Copyright (C) 2015 The Android Open Source Project | ||||||
|  | // | ||||||
|  | // 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 com.google.gerrit.acceptance.git; | ||||||
|  |  | ||||||
|  | import static com.google.common.truth.Truth.assertThat; | ||||||
|  |  | ||||||
|  | import com.google.gerrit.acceptance.AbstractDaemonTest; | ||||||
|  | import com.google.gerrit.common.data.Permission; | ||||||
|  | import com.google.gerrit.reviewdb.client.Project; | ||||||
|  |  | ||||||
|  | import org.eclipse.jgit.junit.TestRepository; | ||||||
|  | import org.eclipse.jgit.lib.Config; | ||||||
|  | import org.eclipse.jgit.lib.ObjectId; | ||||||
|  | import org.eclipse.jgit.revwalk.RevCommit; | ||||||
|  | import org.eclipse.jgit.revwalk.RevObject; | ||||||
|  | import org.eclipse.jgit.revwalk.RevTree; | ||||||
|  | import org.eclipse.jgit.revwalk.RevWalk; | ||||||
|  | import org.eclipse.jgit.transport.RefSpec; | ||||||
|  |  | ||||||
|  | public abstract class AbstractSubmoduleSubscription extends AbstractDaemonTest { | ||||||
|  |   protected TestRepository<?> createProjectWithPush(String name) | ||||||
|  |       throws Exception { | ||||||
|  |     Project.NameKey project = createProject(name); | ||||||
|  |     grant(Permission.PUSH, project, "refs/heads/*"); | ||||||
|  |     grant(Permission.SUBMIT, project, "refs/for/refs/heads/*"); | ||||||
|  |     return cloneProject(project); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   protected void createSubscription( | ||||||
|  |       TestRepository<?> repo, String branch, String subscribeToRepo, | ||||||
|  |       String subscribeToBranch) throws Exception { | ||||||
|  |     subscribeToRepo = name(subscribeToRepo); | ||||||
|  |  | ||||||
|  |     // The submodule subscription module checks for gerrit.canonicalWebUrl to | ||||||
|  |     // detect if it's configured for automatic updates. It doesn't matter if | ||||||
|  |     // it serves from that URL. | ||||||
|  |     String url = cfg.getString("gerrit", null, "canonicalWebUrl") + "/" | ||||||
|  |         + subscribeToRepo; | ||||||
|  |  | ||||||
|  |     Config cfg = new Config(); | ||||||
|  |     cfg.setString("submodule", subscribeToRepo, "path", subscribeToRepo); | ||||||
|  |     cfg.setString("submodule", subscribeToRepo, "url", url); | ||||||
|  |     cfg.setString("submodule", subscribeToRepo, "branch", subscribeToBranch); | ||||||
|  |  | ||||||
|  |     repo.branch("HEAD").commit().insertChangeId() | ||||||
|  |       .message("subject: adding new subscription") | ||||||
|  |       .add(".gitmodules", cfg.toText().toString()) | ||||||
|  |       .create(); | ||||||
|  |  | ||||||
|  |     repo.git().push().setRemote("origin").setRefSpecs( | ||||||
|  |         new RefSpec("HEAD:refs/heads/" + branch)).call(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   protected void expectToHaveSubmoduleState(TestRepository<?> repo, | ||||||
|  |       String branch, String submodule, ObjectId expectedId) throws Exception { | ||||||
|  |  | ||||||
|  |     submodule = name(submodule); | ||||||
|  |     ObjectId commitId = repo.git().fetch().setRemote("origin").call() | ||||||
|  |         .getAdvertisedRef("refs/heads/" + branch).getObjectId(); | ||||||
|  |  | ||||||
|  |     RevWalk rw = repo.getRevWalk(); | ||||||
|  |     RevCommit c = rw.parseCommit(commitId); | ||||||
|  |     rw.parseBody(c.getTree()); | ||||||
|  |  | ||||||
|  |     RevTree tree = c.getTree(); | ||||||
|  |     RevObject actualId = repo.get(tree, submodule); | ||||||
|  |  | ||||||
|  |     assertThat(actualId).isEqualTo(expectedId); | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -8,6 +8,7 @@ acceptance_tests( | |||||||
|     'SubmoduleSubscriptionsIT.java', |     'SubmoduleSubscriptionsIT.java', | ||||||
|     'VisibleRefFilterIT.java', |     'VisibleRefFilterIT.java', | ||||||
|   ], |   ], | ||||||
|  |   deps = [':submodule_util'], | ||||||
|   labels = ['git'], |   labels = ['git'], | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -22,3 +23,9 @@ java_library( | |||||||
|   srcs = ['AbstractPushForReview.java'], |   srcs = ['AbstractPushForReview.java'], | ||||||
|   deps = ['//gerrit-acceptance-tests:lib'], |   deps = ['//gerrit-acceptance-tests:lib'], | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | java_library( | ||||||
|  |   name = 'submodule_util', | ||||||
|  |   srcs = ['AbstractSubmoduleSubscription.java',], | ||||||
|  |   deps = ['//gerrit-acceptance-tests:lib',] | ||||||
|  | ) | ||||||
|   | |||||||
| @@ -16,15 +16,9 @@ package com.google.gerrit.acceptance.git; | |||||||
|  |  | ||||||
| import static com.google.common.truth.Truth.assertThat; | import static com.google.common.truth.Truth.assertThat; | ||||||
|  |  | ||||||
| import com.google.gerrit.acceptance.AbstractDaemonTest; |  | ||||||
| import com.google.gerrit.common.data.Permission; |  | ||||||
| import com.google.gerrit.reviewdb.client.Project; |  | ||||||
|  |  | ||||||
| import org.eclipse.jgit.junit.TestRepository; | import org.eclipse.jgit.junit.TestRepository; | ||||||
| import org.eclipse.jgit.lib.Config; |  | ||||||
| import org.eclipse.jgit.lib.ObjectId; | import org.eclipse.jgit.lib.ObjectId; | ||||||
| import org.eclipse.jgit.revwalk.RevCommit; | import org.eclipse.jgit.revwalk.RevCommit; | ||||||
| import org.eclipse.jgit.revwalk.RevObject; |  | ||||||
| import org.eclipse.jgit.revwalk.RevTree; | import org.eclipse.jgit.revwalk.RevTree; | ||||||
| import org.eclipse.jgit.revwalk.RevWalk; | import org.eclipse.jgit.revwalk.RevWalk; | ||||||
| import org.eclipse.jgit.transport.RefSpec; | import org.eclipse.jgit.transport.RefSpec; | ||||||
| @@ -32,7 +26,7 @@ import org.junit.Test; | |||||||
|  |  | ||||||
| import java.util.concurrent.atomic.AtomicInteger; | import java.util.concurrent.atomic.AtomicInteger; | ||||||
|  |  | ||||||
| public class SubmoduleSubscriptionsIT extends AbstractDaemonTest { | public class SubmoduleSubscriptionsIT extends AbstractSubmoduleSubscription { | ||||||
|  |  | ||||||
|   @Test |   @Test | ||||||
|   public void testSubscriptionToEmptyRepo() throws Exception { |   public void testSubscriptionToEmptyRepo() throws Exception { | ||||||
| @@ -109,14 +103,6 @@ public class SubmoduleSubscriptionsIT extends AbstractDaemonTest { | |||||||
|     assertThat(hasSubmodule(subRepo, "master", "super-project")).isFalse(); |     assertThat(hasSubmodule(subRepo, "master", "super-project")).isFalse(); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   private TestRepository<?> createProjectWithPush(String name) |  | ||||||
|       throws Exception { |  | ||||||
|     Project.NameKey project = createProject(name); |  | ||||||
|     grant(Permission.PUSH, project, "refs/heads/*"); |  | ||||||
|     grant(Permission.SUBMIT, project, "refs/for/refs/heads/*"); |  | ||||||
|     return cloneProject(project); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   private static AtomicInteger contentCounter = new AtomicInteger(0); |   private static AtomicInteger contentCounter = new AtomicInteger(0); | ||||||
|  |  | ||||||
|   private ObjectId pushChangeTo(TestRepository<?> repo, String branch, String message) |   private ObjectId pushChangeTo(TestRepository<?> repo, String branch, String message) | ||||||
| @@ -138,27 +124,6 @@ public class SubmoduleSubscriptionsIT extends AbstractDaemonTest { | |||||||
|     return pushChangeTo(repo, branch, "some change"); |     return pushChangeTo(repo, branch, "some change"); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   private void createSubscription( |  | ||||||
|       TestRepository<?> repo, String branch, String subscribeToRepo, |  | ||||||
|       String subscribeToBranch) throws Exception { |  | ||||||
|     subscribeToRepo = name(subscribeToRepo); |  | ||||||
|  |  | ||||||
|     // The submodule subscription module checks for gerrit.canonicalWebUrl to |  | ||||||
|     // detect if it's configured for automatic updates. It doesn't matter if |  | ||||||
|     // it serves from that URL. |  | ||||||
|     String url = cfg.getString("gerrit", null, "canonicalWebUrl") + "/" |  | ||||||
|         + subscribeToRepo; |  | ||||||
|     String content = buildSubmoduleSection(subscribeToRepo, subscribeToRepo, |  | ||||||
|         url, subscribeToBranch); |  | ||||||
|     repo.branch("HEAD").commit().insertChangeId() |  | ||||||
|       .message("subject: adding new subscription") |  | ||||||
|       .add(".gitmodules", content) |  | ||||||
|       .create(); |  | ||||||
|  |  | ||||||
|     repo.git().push().setRemote("origin").setRefSpecs( |  | ||||||
|         new RefSpec("HEAD:refs/heads/" + branch)).call(); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   private void deleteAllSubscriptions(TestRepository<?> repo, String branch) |   private void deleteAllSubscriptions(TestRepository<?> repo, String branch) | ||||||
|       throws Exception { |       throws Exception { | ||||||
|     repo.git().fetch().setRemote("origin").call(); |     repo.git().fetch().setRemote("origin").call(); | ||||||
| @@ -176,23 +141,6 @@ public class SubmoduleSubscriptionsIT extends AbstractDaemonTest { | |||||||
|     assertThat(actualId).isEqualTo(expectedId); |     assertThat(actualId).isEqualTo(expectedId); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   private void expectToHaveSubmoduleState(TestRepository<?> repo, String branch, |  | ||||||
|       String submodule, ObjectId expectedId) throws Exception { |  | ||||||
|  |  | ||||||
|     submodule = name(submodule); |  | ||||||
|     ObjectId commitId = repo.git().fetch().setRemote("origin").call() |  | ||||||
|         .getAdvertisedRef("refs/heads/" + branch).getObjectId(); |  | ||||||
|  |  | ||||||
|     RevWalk rw = repo.getRevWalk(); |  | ||||||
|     RevCommit c = rw.parseCommit(commitId); |  | ||||||
|     rw.parseBody(c.getTree()); |  | ||||||
|  |  | ||||||
|     RevTree tree = c.getTree(); |  | ||||||
|     RevObject actualId = repo.get(tree, submodule); |  | ||||||
|  |  | ||||||
|     assertThat(actualId).isEqualTo(expectedId); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   private boolean hasSubmodule(TestRepository<?> repo, String branch, |   private boolean hasSubmodule(TestRepository<?> repo, String branch, | ||||||
|       String submodule) throws Exception { |       String submodule) throws Exception { | ||||||
|  |  | ||||||
| @@ -212,12 +160,4 @@ public class SubmoduleSubscriptionsIT extends AbstractDaemonTest { | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   private static String buildSubmoduleSection(String name, |  | ||||||
|       String path, String url, String branch) { |  | ||||||
|     Config cfg = new Config(); |  | ||||||
|     cfg.setString("submodule", name, "path", path); |  | ||||||
|     cfg.setString("submodule", name, "url", url); |  | ||||||
|     cfg.setString("submodule", name, "branch", branch); |  | ||||||
|     return cfg.toText().toString(); |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Stefan Beller
					Stefan Beller