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:
@@ -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,15 +128,15 @@ 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)
|
||||||
|
throws NoSuchProjectException, IOException {
|
||||||
return projectControlFactory.controlFor(
|
return projectControlFactory.controlFor(
|
||||||
new Project.NameKey(repo),
|
new Project.NameKey(repo),
|
||||||
userFactory.create(user)).controlFor(change).getRefControl();
|
userFactory.create(user)).controlFor(change).getRefControl();
|
@@ -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));
|
||||||
|
}
|
||||||
|
}
|
@@ -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));
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user