Extract an abstract test case for querying changes

Add implementations for SQL and Lucene backends.

Convert to JUnit 4 so we can use @Ignore on the test, as Buck's test
runner does not skip abstract classes.

Change-Id: I1a9b6ed53e27cab81ea88ff4e8fece8e999596e0
This commit is contained in:
Dave Borowitz
2013-10-10 11:33:01 -07:00
parent 8122f7edb0
commit fb5744b065
3 changed files with 84 additions and 29 deletions

View File

@@ -14,6 +14,9 @@
package com.google.gerrit.server.query.change; package com.google.gerrit.server.query.change;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import com.google.gerrit.extensions.restapi.TopLevelResource; import com.google.gerrit.extensions.restapi.TopLevelResource;
import com.google.gerrit.lifecycle.LifecycleManager; import com.google.gerrit.lifecycle.LifecycleManager;
import com.google.gerrit.reviewdb.client.Account; import com.google.gerrit.reviewdb.client.Account;
@@ -35,25 +38,25 @@ import com.google.gerrit.server.schema.SchemaCreator;
import com.google.gerrit.server.util.RequestContext; import com.google.gerrit.server.util.RequestContext;
import com.google.gerrit.server.util.ThreadLocalRequestContext; import com.google.gerrit.server.util.ThreadLocalRequestContext;
import com.google.gerrit.testutil.InMemoryDatabase; import com.google.gerrit.testutil.InMemoryDatabase;
import com.google.gerrit.testutil.InMemoryModule;
import com.google.gerrit.testutil.InMemoryRepositoryManager; import com.google.gerrit.testutil.InMemoryRepositoryManager;
import com.google.inject.Guice;
import com.google.inject.Inject; import com.google.inject.Inject;
import com.google.inject.Injector; import com.google.inject.Injector;
import com.google.inject.Provider; import com.google.inject.Provider;
import com.google.inject.util.Providers; import com.google.inject.util.Providers;
import junit.framework.TestCase;
import org.eclipse.jgit.internal.storage.dfs.InMemoryRepository; import org.eclipse.jgit.internal.storage.dfs.InMemoryRepository;
import org.eclipse.jgit.junit.TestRepository; import org.eclipse.jgit.junit.TestRepository;
import org.eclipse.jgit.lib.Config;
import org.eclipse.jgit.revwalk.RevCommit; import org.eclipse.jgit.revwalk.RevCommit;
import org.junit.After;
import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test;
import java.io.IOException; import java.io.IOException;
import java.util.List; import java.util.List;
public class QueryChangesTest extends TestCase { @Ignore
public abstract class AbstractQueryChangesTest {
@Inject private AccountManager accountManager; @Inject private AccountManager accountManager;
@Inject private ChangeInserter.Factory changeFactory; @Inject private ChangeInserter.Factory changeFactory;
@Inject private CreateProject.Factory projectFactory; @Inject private CreateProject.Factory projectFactory;
@@ -69,14 +72,11 @@ public class QueryChangesTest extends TestCase {
private ReviewDb db; private ReviewDb db;
private Account.Id user; private Account.Id user;
@Override protected abstract Injector createInjector();
public void setUp() throws Exception {
Config cfg = InMemoryModule.newDefaultConfig();
cfg.setString("index", null, "type", "lucene");
cfg.setBoolean("index", "lucene", "testInmemory", true);
cfg.setInt("index", "lucene", "testVersion", 2);
Injector injector = Guice.createInjector(new InMemoryModule(cfg)); @Before
public void setUpInjector() throws Exception {
Injector injector = createInjector();
injector.injectMembers(this); injector.injectMembers(this);
lifecycle = new LifecycleManager(); lifecycle = new LifecycleManager();
lifecycle.add(injector); lifecycle.add(injector);
@@ -100,21 +100,16 @@ public class QueryChangesTest extends TestCase {
}); });
} }
@Override @After
public void tearDown() { public void tearDownInjector() {
lifecycle.stop(); lifecycle.stop();
requestContext.setContext(null); requestContext.setContext(null);
db.close(); db.close();
InMemoryDatabase.drop(schemaFactory); InMemoryDatabase.drop(schemaFactory);
} }
@Test
public void testInjectionSetup() { public void byId() throws Exception {
assertNotNull(changeFactory);
assertNotNull(repoManager);
}
public void testQueryById() throws Exception {
TestRepository<InMemoryRepository> repo = createProject("repo"); TestRepository<InMemoryRepository> repo = createProject("repo");
RevCommit commit = repo.parseBody(repo.commit().message("message").create()); RevCommit commit = repo.parseBody(repo.commit().message("message").create());
Change change = new Change( Change change = new Change(
@@ -133,19 +128,19 @@ public class QueryChangesTest extends TestCase {
assertEquals(id, result._number); assertEquals(id, result._number);
} }
private TestRepository<InMemoryRepository> createProject(String name) private TestRepository<InMemoryRepository> createProject(String name) throws Exception {
throws Exception {
CreateProject create = projectFactory.create(name); CreateProject create = projectFactory.create(name);
create.apply(TopLevelResource.INSTANCE, new CreateProject.Input()); create.apply(TopLevelResource.INSTANCE, new CreateProject.Input());
return new TestRepository<InMemoryRepository>( return new TestRepository<InMemoryRepository>(
repoManager.openRepository(new Project.NameKey(name))); repoManager.openRepository(new Project.NameKey(name)));
} }
private RefControl refControl(String repo, Change change) throws NoSuchProjectException, IOException { private RefControl refControl(String repo, Change change)
return projectControlFactory.controlFor( throws NoSuchProjectException, IOException {
new Project.NameKey(repo), return projectControlFactory.controlFor(
userFactory.create(user)).controlFor(change).getRefControl(); new Project.NameKey(repo),
} userFactory.create(user)).controlFor(change).getRefControl();
}
private ChangeInfo queryOne(String query) throws Exception { private ChangeInfo queryOne(String query) throws Exception {
QueryChanges q = queryProvider.get(); QueryChanges q = queryProvider.get();

View File

@@ -0,0 +1,31 @@
// Copyright (C) 2013 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.server.git;
package com.google.gerrit.server.query.change;
import com.google.gerrit.testutil.InMemoryModule;
import com.google.inject.Guice;
import com.google.inject.Injector;
import org.eclipse.jgit.lib.Config;
public class LuceneQueryChangesTest extends AbstractQueryChangesTest {
protected Injector createInjector() {
Config cfg = InMemoryModule.newDefaultConfig();
cfg.setString("index", null, "type", "lucene");
cfg.setBoolean("index", "lucene", "testInmemory", true);
cfg.setInt("index", "lucene", "testVersion", 4);
return Guice.createInjector(new InMemoryModule(cfg));
}
}

View File

@@ -0,0 +1,29 @@
// Copyright (C) 2013 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.server.git;
package com.google.gerrit.server.query.change;
import com.google.gerrit.testutil.InMemoryModule;
import com.google.inject.Guice;
import com.google.inject.Injector;
import org.eclipse.jgit.lib.Config;
public class SqlQueryChangesTest extends AbstractQueryChangesTest {
protected Injector createInjector() {
Config cfg = InMemoryModule.newDefaultConfig();
cfg.setString("index", null, "type", "sql");
return Guice.createInjector(new InMemoryModule(cfg));
}
}