/javatests/com/google/gerrit/elasticsearch/ElasticQueryChangesTest.java
https://gitlab.com/chenfengxu/gerrit · Java · 87 lines · 63 code · 10 blank · 14 comment · 6 complexity · fad740ae70a606ac6d900a3b953890bf MD5 · raw file
- // Copyright (C) 2014 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.elasticsearch;
- import com.google.gerrit.elasticsearch.ElasticTestUtils.ElasticNodeInfo;
- import com.google.gerrit.server.query.change.AbstractQueryChangesTest;
- import com.google.gerrit.testing.ConfigSuite;
- import com.google.gerrit.testing.InMemoryModule;
- import com.google.gerrit.testing.InMemoryRepositoryManager.Repo;
- import com.google.gerrit.testing.IndexConfig;
- import com.google.inject.Guice;
- import com.google.inject.Injector;
- import java.util.concurrent.ExecutionException;
- import org.eclipse.jgit.junit.TestRepository;
- import org.eclipse.jgit.lib.Config;
- import org.junit.After;
- import org.junit.AfterClass;
- import org.junit.BeforeClass;
- import org.junit.Test;
- public class ElasticQueryChangesTest extends AbstractQueryChangesTest {
- @ConfigSuite.Default
- public static Config defaultConfig() {
- return IndexConfig.createForElasticsearch();
- }
- private static ElasticNodeInfo nodeInfo;
- @BeforeClass
- public static void startIndexService() throws InterruptedException, ExecutionException {
- if (nodeInfo != null) {
- // do not start Elasticsearch twice
- return;
- }
- nodeInfo = ElasticTestUtils.startElasticsearchNode();
- }
- @AfterClass
- public static void stopElasticsearchServer() {
- if (nodeInfo != null) {
- nodeInfo.node.close();
- nodeInfo.elasticDir.delete();
- nodeInfo = null;
- }
- }
- private String testName() {
- return testName.getMethodName().toLowerCase() + "_";
- }
- @After
- public void cleanupIndex() {
- if (nodeInfo != null) {
- ElasticTestUtils.deleteAllIndexes(nodeInfo, testName());
- }
- }
- @Override
- protected Injector createInjector() {
- Config elasticsearchConfig = new Config(config);
- InMemoryModule.setDefaults(elasticsearchConfig);
- String indicesPrefix = testName();
- ElasticTestUtils.configure(elasticsearchConfig, nodeInfo.port, indicesPrefix);
- ElasticTestUtils.createAllIndexes(nodeInfo, indicesPrefix);
- return Guice.createInjector(new InMemoryModule(elasticsearchConfig, notesMigration));
- }
- @Test
- public void byOwnerInvalidQuery() throws Exception {
- TestRepository<Repo> repo = createProject("repo");
- insert(repo, newChange(repo), userId);
- String nameEmail = user.asIdentifiedUser().getNameEmail();
- assertQuery("owner: \"" + nameEmail + "\"\\");
- }
- }