More ImmutableMap banning
Original commit: elastic/x-pack-elasticsearch@59fee6e288
This commit is contained in:
parent
eb60d5925a
commit
1d61278b2d
|
@ -6,6 +6,7 @@
|
||||||
package org.elasticsearch.shield.authc.esusers;
|
package org.elasticsearch.shield.authc.esusers;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchException;
|
import org.elasticsearch.ElasticsearchException;
|
||||||
import org.elasticsearch.common.inject.internal.Nullable;
|
import org.elasticsearch.common.inject.internal.Nullable;
|
||||||
import org.elasticsearch.common.logging.ESLogger;
|
import org.elasticsearch.common.logging.ESLogger;
|
||||||
|
@ -32,6 +33,7 @@ import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.CopyOnWriteArrayList;
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
import static org.elasticsearch.shield.support.ShieldFiles.openAtomicMoveWriter;
|
import static org.elasticsearch.shield.support.ShieldFiles.openAtomicMoveWriter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -44,7 +46,7 @@ public class FileUserPasswdStore {
|
||||||
private final Path file;
|
private final Path file;
|
||||||
final Hasher hasher = Hasher.BCRYPT;
|
final Hasher hasher = Hasher.BCRYPT;
|
||||||
|
|
||||||
private volatile ImmutableMap<String, char[]> users;
|
private volatile Map<String, char[]> users;
|
||||||
|
|
||||||
private CopyOnWriteArrayList<RefreshListener> listeners;
|
private CopyOnWriteArrayList<RefreshListener> listeners;
|
||||||
|
|
||||||
|
@ -105,12 +107,12 @@ public class FileUserPasswdStore {
|
||||||
* Internally in this class, we try to load the file, but if for some reason we can't, we're being more lenient by
|
* Internally in this class, we try to load the file, but if for some reason we can't, we're being more lenient by
|
||||||
* logging the error and skipping all users. This is aligned with how we handle other auto-loaded files in shield.
|
* logging the error and skipping all users. This is aligned with how we handle other auto-loaded files in shield.
|
||||||
*/
|
*/
|
||||||
static ImmutableMap<String, char[]> parseFileLenient(Path path, ESLogger logger) {
|
static Map<String, char[]> parseFileLenient(Path path, ESLogger logger) {
|
||||||
try {
|
try {
|
||||||
return parseFile(path, logger);
|
return parseFile(path, logger);
|
||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
logger.error("failed to parse users file [{}]. skipping/removing all users...", t, path.toAbsolutePath());
|
logger.error("failed to parse users file [{}]. skipping/removing all users...", t, path.toAbsolutePath());
|
||||||
return ImmutableMap.of();
|
return emptyMap();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,14 +120,14 @@ public class FileUserPasswdStore {
|
||||||
* parses the esusers file. Should never return {@code null}, if the file doesn't exist an
|
* parses the esusers file. Should never return {@code null}, if the file doesn't exist an
|
||||||
* empty map is returned
|
* empty map is returned
|
||||||
*/
|
*/
|
||||||
public static ImmutableMap<String, char[]> parseFile(Path path, @Nullable ESLogger logger) {
|
public static Map<String, char[]> parseFile(Path path, @Nullable ESLogger logger) {
|
||||||
if (logger == null) {
|
if (logger == null) {
|
||||||
logger = NoOpLogger.INSTANCE;
|
logger = NoOpLogger.INSTANCE;
|
||||||
}
|
}
|
||||||
logger.trace("reading users file [{}]...", path.toAbsolutePath());
|
logger.trace("reading users file [{}]...", path.toAbsolutePath());
|
||||||
|
|
||||||
if (!Files.exists(path)) {
|
if (!Files.exists(path)) {
|
||||||
return ImmutableMap.of();
|
return emptyMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
List<String> lines;
|
List<String> lines;
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
package org.elasticsearch.shield.authc.esusers;
|
package org.elasticsearch.shield.authc.esusers;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchException;
|
import org.elasticsearch.ElasticsearchException;
|
||||||
import org.elasticsearch.common.Strings;
|
import org.elasticsearch.common.Strings;
|
||||||
import org.elasticsearch.common.inject.internal.Nullable;
|
import org.elasticsearch.common.inject.internal.Nullable;
|
||||||
|
@ -26,10 +27,15 @@ import java.io.PrintWriter;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.concurrent.CopyOnWriteArrayList;
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
import static org.elasticsearch.shield.support.ShieldFiles.openAtomicMoveWriter;
|
import static org.elasticsearch.shield.support.ShieldFiles.openAtomicMoveWriter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -43,7 +49,7 @@ public class FileUserRolesStore {
|
||||||
|
|
||||||
private final Path file;
|
private final Path file;
|
||||||
private CopyOnWriteArrayList<RefreshListener> listeners;
|
private CopyOnWriteArrayList<RefreshListener> listeners;
|
||||||
private volatile ImmutableMap<String, String[]> userRoles;
|
private volatile Map<String, String[]> userRoles;
|
||||||
|
|
||||||
public FileUserRolesStore(RealmConfig config, ResourceWatcherService watcherService) {
|
public FileUserRolesStore(RealmConfig config, ResourceWatcherService watcherService) {
|
||||||
this(config, watcherService, null);
|
this(config, watcherService, null);
|
||||||
|
@ -95,12 +101,12 @@ public class FileUserRolesStore {
|
||||||
* Internally in this class, we try to load the file, but if for some reason we can't, we're being more lenient by
|
* Internally in this class, we try to load the file, but if for some reason we can't, we're being more lenient by
|
||||||
* logging the error and skipping all enries. This is aligned with how we handle other auto-loaded files in shield.
|
* logging the error and skipping all enries. This is aligned with how we handle other auto-loaded files in shield.
|
||||||
*/
|
*/
|
||||||
static ImmutableMap<String, String[]> parseFileLenient(Path path, ESLogger logger) {
|
static Map<String, String[]> parseFileLenient(Path path, ESLogger logger) {
|
||||||
try {
|
try {
|
||||||
return parseFile(path, logger);
|
return parseFile(path, logger);
|
||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
logger.error("failed to parse users_roles file [{}]. skipping/removing all entries...", t, path.toAbsolutePath());
|
logger.error("failed to parse users_roles file [{}]. skipping/removing all entries...", t, path.toAbsolutePath());
|
||||||
return ImmutableMap.of();
|
return emptyMap();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,7 +115,7 @@ public class FileUserRolesStore {
|
||||||
* an empty map is returned. The read file holds a mapping per line of the form "role -> users" while the returned
|
* an empty map is returned. The read file holds a mapping per line of the form "role -> users" while the returned
|
||||||
* map holds entries of the form "user -> roles".
|
* map holds entries of the form "user -> roles".
|
||||||
*/
|
*/
|
||||||
public static ImmutableMap<String, String[]> parseFile(Path path, @Nullable ESLogger logger) {
|
public static Map<String, String[]> parseFile(Path path, @Nullable ESLogger logger) {
|
||||||
if (logger == null) {
|
if (logger == null) {
|
||||||
logger = NoOpLogger.INSTANCE;
|
logger = NoOpLogger.INSTANCE;
|
||||||
}
|
}
|
||||||
|
@ -117,7 +123,7 @@ public class FileUserRolesStore {
|
||||||
|
|
||||||
|
|
||||||
if (!Files.exists(path)) {
|
if (!Files.exists(path)) {
|
||||||
return ImmutableMap.of();
|
return emptyMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
List<String> lines;
|
List<String> lines;
|
||||||
|
|
|
@ -5,9 +5,9 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.shield.authc.support;
|
package org.elasticsearch.shield.authc.support;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import com.unboundid.ldap.sdk.DN;
|
import com.unboundid.ldap.sdk.DN;
|
||||||
import com.unboundid.ldap.sdk.LDAPException;
|
import com.unboundid.ldap.sdk.LDAPException;
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchException;
|
import org.elasticsearch.ElasticsearchException;
|
||||||
import org.elasticsearch.common.Nullable;
|
import org.elasticsearch.common.Nullable;
|
||||||
import org.elasticsearch.common.logging.ESLogger;
|
import org.elasticsearch.common.logging.ESLogger;
|
||||||
|
@ -23,9 +23,15 @@ import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.*;
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.concurrent.CopyOnWriteArrayList;
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static java.util.Collections.unmodifiableMap;
|
||||||
import static org.elasticsearch.shield.authc.ldap.support.LdapUtils.dn;
|
import static org.elasticsearch.shield.authc.ldap.support.LdapUtils.dn;
|
||||||
import static org.elasticsearch.shield.authc.ldap.support.LdapUtils.relativeName;
|
import static org.elasticsearch.shield.authc.ldap.support.LdapUtils.relativeName;
|
||||||
|
|
||||||
|
@ -44,7 +50,7 @@ public class DnRoleMapper {
|
||||||
private final String realmType;
|
private final String realmType;
|
||||||
private final Path file;
|
private final Path file;
|
||||||
private final boolean useUnmappedGroupsAsRoles;
|
private final boolean useUnmappedGroupsAsRoles;
|
||||||
protected volatile ImmutableMap<DN, Set<String>> dnRoles;
|
protected volatile Map<DN, Set<String>> dnRoles;
|
||||||
|
|
||||||
private CopyOnWriteArrayList<RefreshListener> listeners;
|
private CopyOnWriteArrayList<RefreshListener> listeners;
|
||||||
|
|
||||||
|
@ -86,21 +92,21 @@ public class DnRoleMapper {
|
||||||
* logging the error and skipping/removing all mappings. This is aligned with how we handle other auto-loaded files
|
* logging the error and skipping/removing all mappings. This is aligned with how we handle other auto-loaded files
|
||||||
* in shield.
|
* in shield.
|
||||||
*/
|
*/
|
||||||
public static ImmutableMap<DN, Set<String>> parseFileLenient(Path path, ESLogger logger, String realmType, String realmName) {
|
public static Map<DN, Set<String>> parseFileLenient(Path path, ESLogger logger, String realmType, String realmName) {
|
||||||
try {
|
try {
|
||||||
return parseFile(path, logger, realmType, realmName);
|
return parseFile(path, logger, realmType, realmName);
|
||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
logger.error("failed to parse role mappings file [{}]. skipping/removing all mappings...", t, path.toAbsolutePath());
|
logger.error("failed to parse role mappings file [{}]. skipping/removing all mappings...", t, path.toAbsolutePath());
|
||||||
return ImmutableMap.of();
|
return emptyMap();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ImmutableMap<DN, Set<String>> parseFile(Path path, ESLogger logger, String realmType, String realmName) {
|
public static Map<DN, Set<String>> parseFile(Path path, ESLogger logger, String realmType, String realmName) {
|
||||||
|
|
||||||
logger.trace("reading realm [{}/{}] role mappings file [{}]...", realmType, realmName, path.toAbsolutePath());
|
logger.trace("reading realm [{}/{}] role mappings file [{}]...", realmType, realmName, path.toAbsolutePath());
|
||||||
|
|
||||||
if (!Files.exists(path)) {
|
if (!Files.exists(path)) {
|
||||||
return ImmutableMap.of();
|
return emptyMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
try (InputStream in = Files.newInputStream(path)) {
|
try (InputStream in = Files.newInputStream(path)) {
|
||||||
|
@ -131,7 +137,7 @@ public class DnRoleMapper {
|
||||||
logger.warn("no mappings found in role mappings file [{}] for realm [{}/{}]", path.toAbsolutePath(), realmType, realmName);
|
logger.warn("no mappings found in role mappings file [{}] for realm [{}/{}]", path.toAbsolutePath(), realmType, realmName);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ImmutableMap.copyOf(dnToRoles);
|
return unmodifiableMap(dnToRoles);
|
||||||
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new ElasticsearchException("could not read realm [" + realmType + "/" + realmName + "] role mappings file [" + path.toAbsolutePath() + "]", e);
|
throw new ElasticsearchException("could not read realm [" + realmType + "/" + realmName + "] role mappings file [" + path.toAbsolutePath() + "]", e);
|
||||||
|
|
|
@ -30,6 +30,8 @@ import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
import java.util.function.Predicate;
|
import java.util.function.Predicate;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static java.util.Collections.unmodifiableMap;
|
||||||
import static java.util.Collections.unmodifiableSet;
|
import static java.util.Collections.unmodifiableSet;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -443,9 +445,9 @@ public interface Permission {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ImmutableMap<String, IndicesAccessControl.IndexAccessControl> authorize(String action, Set<String> requestedIndicesOrAliases, MetaData metaData) {
|
public Map<String, IndicesAccessControl.IndexAccessControl> authorize(String action, Set<String> requestedIndicesOrAliases, MetaData metaData) {
|
||||||
if (isEmpty()) {
|
if (isEmpty()) {
|
||||||
return ImmutableMap.of();
|
return emptyMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
// What this code does is just merge `IndexAccessControl` instances from the permissions this class holds:
|
// What this code does is just merge `IndexAccessControl` instances from the permissions this class holds:
|
||||||
|
@ -466,9 +468,9 @@ public interface Permission {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (indicesAccessControl == null) {
|
if (indicesAccessControl == null) {
|
||||||
return ImmutableMap.of();
|
return emptyMap();
|
||||||
} else {
|
} else {
|
||||||
return ImmutableMap.copyOf(indicesAccessControl);
|
return unmodifiableMap(indicesAccessControl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
package org.elasticsearch.shield.transport.filter;
|
package org.elasticsearch.shield.transport.filter;
|
||||||
|
|
||||||
import com.carrotsearch.hppc.ObjectObjectHashMap;
|
import com.carrotsearch.hppc.ObjectObjectHashMap;
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchException;
|
import org.elasticsearch.ElasticsearchException;
|
||||||
import org.elasticsearch.common.collect.HppcMaps;
|
import org.elasticsearch.common.collect.HppcMaps;
|
||||||
import org.elasticsearch.common.component.AbstractLifecycleComponent;
|
import org.elasticsearch.common.component.AbstractLifecycleComponent;
|
||||||
|
@ -23,7 +23,14 @@ import org.elasticsearch.shield.audit.AuditTrail;
|
||||||
import org.elasticsearch.transport.Transport;
|
import org.elasticsearch.transport.Transport;
|
||||||
|
|
||||||
import java.net.InetAddress;
|
import java.net.InetAddress;
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.unmodifiableMap;
|
||||||
|
|
||||||
public class IPFilter extends AbstractLifecycleComponent<IPFilter> {
|
public class IPFilter extends AbstractLifecycleComponent<IPFilter> {
|
||||||
|
|
||||||
|
@ -174,7 +181,7 @@ public class IPFilter extends AbstractLifecycleComponent<IPFilter> {
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.debug("loaded ip filtering profiles: {}", profileRules.keySet());
|
logger.debug("loaded ip filtering profiles: {}", profileRules.keySet());
|
||||||
return ImmutableMap.copyOf(profileRules);
|
return unmodifiableMap(profileRules);
|
||||||
}
|
}
|
||||||
|
|
||||||
private ShieldIpFilterRule[] createRules(String[] allow, String[] deny, TransportAddress[] boundAddresses) {
|
private ShieldIpFilterRule[] createRules(String[] allow, String[] deny, TransportAddress[] boundAddresses) {
|
||||||
|
|
|
@ -5,22 +5,21 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.integration;
|
package org.elasticsearch.integration;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchException;
|
import org.elasticsearch.ElasticsearchException;
|
||||||
import org.elasticsearch.action.admin.cluster.snapshots.status.SnapshotsStatusResponse;
|
import org.elasticsearch.action.admin.cluster.snapshots.status.SnapshotsStatusResponse;
|
||||||
import org.elasticsearch.cluster.SnapshotsInProgress;
|
import org.elasticsearch.cluster.SnapshotsInProgress;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.node.Node;
|
import org.elasticsearch.node.Node;
|
||||||
|
import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
||||||
import org.elasticsearch.test.junit.annotations.TestLogging;
|
import org.elasticsearch.test.junit.annotations.TestLogging;
|
||||||
import org.junit.AfterClass;
|
import org.junit.AfterClass;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
|
||||||
import static org.elasticsearch.test.ESIntegTestCase.Scope.TEST;
|
import static org.elasticsearch.test.ESIntegTestCase.Scope.TEST;
|
||||||
|
|
||||||
@ClusterScope(scope = TEST)
|
@ClusterScope(scope = TEST)
|
||||||
|
@ -83,7 +82,6 @@ public class ClusterPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
return super.configUsersRoles() + USERS_ROLES;
|
return super.configUsersRoles() + USERS_ROLES;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
@TestLogging("org.elasticsearch.test.rest.client.http:TRACE")
|
@TestLogging("org.elasticsearch.test.rest.client.http:TRACE")
|
||||||
public void testThatClusterPrivilegesWorkAsExpectedViaHttp() throws Exception {
|
public void testThatClusterPrivilegesWorkAsExpectedViaHttp() throws Exception {
|
||||||
// user_a can do all the things
|
// user_a can do all the things
|
||||||
|
@ -124,7 +122,6 @@ public class ClusterPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertAccessIsDenied("user_c", "PUT", "/_cluster/settings", "{ \"transient\" : { \"indices.ttl.interval\": \"1m\" } }");
|
assertAccessIsDenied("user_c", "PUT", "/_cluster/settings", "{ \"transient\" : { \"indices.ttl.interval\": \"1m\" } }");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
@TestLogging("org.elasticsearch.test.rest.client.http:TRACE")
|
@TestLogging("org.elasticsearch.test.rest.client.http:TRACE")
|
||||||
public void testThatSnapshotAndRestore() throws Exception {
|
public void testThatSnapshotAndRestore() throws Exception {
|
||||||
String repoJson = jsonBuilder().startObject().field("type", "fs").startObject("settings").field("location", repositoryLocation.toString()).endObject().endObject().string();
|
String repoJson = jsonBuilder().startObject().field("type", "fs").startObject("settings").field("location", repositoryLocation.toString()).endObject().endObject().string();
|
||||||
|
@ -132,7 +129,7 @@ public class ClusterPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertAccessIsDenied("user_c", "PUT", "/_snapshot/my-repo", repoJson);
|
assertAccessIsDenied("user_c", "PUT", "/_snapshot/my-repo", repoJson);
|
||||||
assertAccessIsAllowed("user_a", "PUT", "/_snapshot/my-repo", repoJson);
|
assertAccessIsAllowed("user_a", "PUT", "/_snapshot/my-repo", repoJson);
|
||||||
|
|
||||||
ImmutableMap params = ImmutableMap.of("refresh", "true");
|
Map<String, String> params = singletonMap("refresh", "true");
|
||||||
assertAccessIsDenied("user_a", "PUT", "/someindex/bar/1", "{ \"name\" : \"elasticsearch\" }", params);
|
assertAccessIsDenied("user_a", "PUT", "/someindex/bar/1", "{ \"name\" : \"elasticsearch\" }", params);
|
||||||
assertAccessIsDenied("user_b", "PUT", "/someindex/bar/1", "{ \"name\" : \"elasticsearch\" }", params);
|
assertAccessIsDenied("user_b", "PUT", "/someindex/bar/1", "{ \"name\" : \"elasticsearch\" }", params);
|
||||||
assertAccessIsAllowed("user_c", "PUT", "/someindex/bar/1", "{ \"name\" : \"elasticsearch\" }", params);
|
assertAccessIsAllowed("user_c", "PUT", "/someindex/bar/1", "{ \"name\" : \"elasticsearch\" }", params);
|
||||||
|
@ -152,11 +149,10 @@ public class ClusterPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertAccessIsDenied("user_b", "DELETE", "/someindex");
|
assertAccessIsDenied("user_b", "DELETE", "/someindex");
|
||||||
assertAccessIsAllowed("user_c", "DELETE", "/someindex");
|
assertAccessIsAllowed("user_c", "DELETE", "/someindex");
|
||||||
|
|
||||||
ImmutableMap restoreParams = ImmutableMap.of("wait_for_completion", "true");
|
params = singletonMap("wait_for_completion", "true");
|
||||||
assertAccessIsDenied("user_b", "POST", "/_snapshot/my-repo/my-snapshot/_restore", null, restoreParams);
|
assertAccessIsDenied("user_b", "POST", "/_snapshot/my-repo/my-snapshot/_restore", null, params);
|
||||||
assertAccessIsDenied("user_c", "POST", "/_snapshot/my-repo/my-snapshot/_restore", null, restoreParams);
|
assertAccessIsDenied("user_c", "POST", "/_snapshot/my-repo/my-snapshot/_restore", null, params);
|
||||||
|
assertAccessIsAllowed("user_a", "POST", "/_snapshot/my-repo/my-snapshot/_restore", null, params);
|
||||||
assertAccessIsAllowed("user_a", "POST", "/_snapshot/my-repo/my-snapshot/_restore", null, restoreParams);
|
|
||||||
|
|
||||||
assertAccessIsDenied("user_a", "GET", "/someindex/bar/1");
|
assertAccessIsDenied("user_a", "GET", "/someindex/bar/1");
|
||||||
assertAccessIsDenied("user_b", "GET", "/someindex/bar/1");
|
assertAccessIsDenied("user_b", "GET", "/someindex/bar/1");
|
||||||
|
|
|
@ -5,16 +5,16 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.integration;
|
package org.elasticsearch.integration;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.node.Node;
|
import org.elasticsearch.node.Node;
|
||||||
import org.elasticsearch.test.rest.client.http.HttpResponse;
|
import org.elasticsearch.test.rest.client.http.HttpResponse;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.hamcrest.Matchers.is;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
|
||||||
public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
|
@ -138,14 +138,13 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
@Before
|
@Before
|
||||||
public void insertBaseDocumentsAsAdmin() throws Exception {
|
public void insertBaseDocumentsAsAdmin() throws Exception {
|
||||||
// indices: a,b,c,abc
|
// indices: a,b,c,abc
|
||||||
ImmutableMap<String, String> params = ImmutableMap.of("refresh", "true");
|
Map<String, String> params = singletonMap("refresh", "true");
|
||||||
assertAccessIsAllowed("admin", "PUT", "/a/foo/1", jsonDoc, params);
|
assertAccessIsAllowed("admin", "PUT", "/a/foo/1", jsonDoc, params);
|
||||||
assertAccessIsAllowed("admin", "PUT", "/b/foo/1", jsonDoc, params);
|
assertAccessIsAllowed("admin", "PUT", "/b/foo/1", jsonDoc, params);
|
||||||
assertAccessIsAllowed("admin", "PUT", "/c/foo/1", jsonDoc, params);
|
assertAccessIsAllowed("admin", "PUT", "/c/foo/1", jsonDoc, params);
|
||||||
assertAccessIsAllowed("admin", "PUT", "/abc/foo/1", jsonDoc, params);
|
assertAccessIsAllowed("admin", "PUT", "/abc/foo/1", jsonDoc, params);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU1() throws Exception {
|
public void testUserU1() throws Exception {
|
||||||
// u1 has all_a_role and read_a_role
|
// u1 has all_a_role and read_a_role
|
||||||
assertUserIsAllowed("u1", "all", "a");
|
assertUserIsAllowed("u1", "all", "a");
|
||||||
|
@ -153,7 +152,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u1", "all", "c");
|
assertUserIsDenied("u1", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU2() throws Exception {
|
public void testUserU2() throws Exception {
|
||||||
// u2 has all_all and read a/b role
|
// u2 has all_all and read a/b role
|
||||||
assertUserIsAllowed("u2", "all", "a");
|
assertUserIsAllowed("u2", "all", "a");
|
||||||
|
@ -164,7 +162,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u2", "all", "c");
|
assertUserIsDenied("u2", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU3() throws Exception {
|
public void testUserU3() throws Exception {
|
||||||
// u3 has get b role, but all access to a* and b* via regex
|
// u3 has get b role, but all access to a* and b* via regex
|
||||||
assertUserIsAllowed("u3", "all", "a");
|
assertUserIsAllowed("u3", "all", "a");
|
||||||
|
@ -172,7 +169,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u3", "all", "c");
|
assertUserIsDenied("u3", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU4() throws Exception {
|
public void testUserU4() throws Exception {
|
||||||
// u4 has read access to a/b and manage access to a*
|
// u4 has read access to a/b and manage access to a*
|
||||||
assertUserIsAllowed("u4", "read", "a");
|
assertUserIsAllowed("u4", "read", "a");
|
||||||
|
@ -189,7 +185,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsAllowed("u4", "manage", "an_index");
|
assertUserIsAllowed("u4", "manage", "an_index");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU5() throws Exception {
|
public void testUserU5() throws Exception {
|
||||||
// u5 may read a and get b
|
// u5 may read a and get b
|
||||||
assertUserIsAllowed("u5", "read", "a");
|
assertUserIsAllowed("u5", "read", "a");
|
||||||
|
@ -202,7 +197,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertAccessIsDenied("u5", "GET", "/b/_search");
|
assertAccessIsDenied("u5", "GET", "/b/_search");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU6() throws Exception {
|
public void testUserU6() throws Exception {
|
||||||
// u6 has all access on a and search access on b
|
// u6 has all access on a and search access on b
|
||||||
assertUserIsAllowed("u6", "all", "a");
|
assertUserIsAllowed("u6", "all", "a");
|
||||||
|
@ -212,7 +206,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u6", "all", "c");
|
assertUserIsDenied("u6", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU7() throws Exception {
|
public void testUserU7() throws Exception {
|
||||||
// no access at all
|
// no access at all
|
||||||
assertUserIsDenied("u7", "all", "a");
|
assertUserIsDenied("u7", "all", "a");
|
||||||
|
@ -220,7 +213,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u7", "all", "c");
|
assertUserIsDenied("u7", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU8() throws Exception {
|
public void testUserU8() throws Exception {
|
||||||
// u8 has admin access and get access on b
|
// u8 has admin access and get access on b
|
||||||
assertUserIsAllowed("u8", "all", "a");
|
assertUserIsAllowed("u8", "all", "a");
|
||||||
|
@ -228,7 +220,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsAllowed("u8", "all", "c");
|
assertUserIsAllowed("u8", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU9() throws Exception {
|
public void testUserU9() throws Exception {
|
||||||
// u9 has write access to a and read access to a/b
|
// u9 has write access to a and read access to a/b
|
||||||
assertUserIsAllowed("u9", "crud", "a");
|
assertUserIsAllowed("u9", "crud", "a");
|
||||||
|
@ -239,7 +230,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u9", "all", "c");
|
assertUserIsDenied("u9", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU10() throws Exception {
|
public void testUserU10() throws Exception {
|
||||||
// u10 has access on get/search on b
|
// u10 has access on get/search on b
|
||||||
assertUserIsDenied("u10", "all", "a");
|
assertUserIsDenied("u10", "all", "a");
|
||||||
|
@ -249,7 +239,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u10", "all", "c");
|
assertUserIsDenied("u10", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU11() throws Exception {
|
public void testUserU11() throws Exception {
|
||||||
// u11 has access to create c and delete b
|
// u11 has access to create c and delete b
|
||||||
assertUserIsDenied("u11", "all", "a");
|
assertUserIsDenied("u11", "all", "a");
|
||||||
|
@ -265,7 +254,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u11", "monitor", "c");
|
assertUserIsDenied("u11", "monitor", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU12() throws Exception {
|
public void testUserU12() throws Exception {
|
||||||
// u12 has data_access to all indices+ crud access to a
|
// u12 has data_access to all indices+ crud access to a
|
||||||
assertUserIsDenied("u12", "manage", "a");
|
assertUserIsDenied("u12", "manage", "a");
|
||||||
|
@ -276,7 +264,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsAllowed("u12", "data_access", "c");
|
assertUserIsAllowed("u12", "data_access", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU13() throws Exception {
|
public void testUserU13() throws Exception {
|
||||||
// u13 has search access on b and index access on a
|
// u13 has search access on b and index access on a
|
||||||
assertUserIsDenied("u13", "manage", "a");
|
assertUserIsDenied("u13", "manage", "a");
|
||||||
|
@ -291,7 +278,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u13", "all", "c");
|
assertUserIsDenied("u13", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU14() throws Exception {
|
public void testUserU14() throws Exception {
|
||||||
// u14 has access to read a and monitor b
|
// u14 has access to read a and monitor b
|
||||||
assertUserIsDenied("u14", "manage", "a");
|
assertUserIsDenied("u14", "manage", "a");
|
||||||
|
@ -306,7 +292,6 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u14", "all", "c");
|
assertUserIsDenied("u14", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserU15() throws Exception {
|
public void testUserU15() throws Exception {
|
||||||
//u15 has access to manage and search a, so that adding warmer templates work
|
//u15 has access to manage and search a, so that adding warmer templates work
|
||||||
assertUserIsAllowed("u15", "manage", "a");
|
assertUserIsAllowed("u15", "manage", "a");
|
||||||
|
@ -318,14 +303,13 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertUserIsDenied("u15", "all", "c");
|
assertUserIsDenied("u15", "all", "c");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testThatUnknownUserIsRejectedProperly() throws Exception {
|
public void testThatUnknownUserIsRejectedProperly() throws Exception {
|
||||||
HttpResponse response = executeRequest("idonotexist", "GET", "/", null, new HashMap<>());
|
HttpResponse response = executeRequest("idonotexist", "GET", "/", null, new HashMap<>());
|
||||||
assertThat(response.getStatusCode(), is(401));
|
assertThat(response.getStatusCode(), is(401));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertUserExecutes(String user, String action, String index, boolean userIsAllowed) throws Exception {
|
private void assertUserExecutes(String user, String action, String index, boolean userIsAllowed) throws Exception {
|
||||||
ImmutableMap<String, String> refreshParams = ImmutableMap.of("refresh", "true");
|
Map<String, String> refreshParams = singletonMap("refresh", "true");
|
||||||
|
|
||||||
switch (action) {
|
switch (action) {
|
||||||
case "all" :
|
case "all" :
|
||||||
|
@ -353,7 +337,7 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
// wait until index ready, but as admin
|
// wait until index ready, but as admin
|
||||||
client().admin().cluster().prepareHealth(index).setWaitForGreenStatus().get();
|
client().admin().cluster().prepareHealth(index).setWaitForGreenStatus().get();
|
||||||
assertAccessIsAllowed(user, "POST", "/" + index + "/_refresh");
|
assertAccessIsAllowed(user, "POST", "/" + index + "/_refresh");
|
||||||
ImmutableMap<String, String> analyzeParams = ImmutableMap.of("text", "test");
|
Map<String, String> analyzeParams = singletonMap("text", "test");
|
||||||
assertAccessIsAllowed(user, "GET", "/" + index + "/_analyze", null, analyzeParams);
|
assertAccessIsAllowed(user, "GET", "/" + index + "/_analyze", null, analyzeParams);
|
||||||
assertAccessIsAllowed(user, "POST", "/" + index + "/_flush");
|
assertAccessIsAllowed(user, "POST", "/" + index + "/_flush");
|
||||||
assertAccessIsAllowed(user, "POST", "/" + index + "/_optimize");
|
assertAccessIsAllowed(user, "POST", "/" + index + "/_optimize");
|
||||||
|
@ -374,7 +358,7 @@ public class IndexPrivilegeTests extends AbstractPrivilegeTestCase {
|
||||||
assertAccessIsDenied(user, "DELETE", "/" + index);
|
assertAccessIsDenied(user, "DELETE", "/" + index);
|
||||||
assertUserIsDenied(user, "create_index", index);
|
assertUserIsDenied(user, "create_index", index);
|
||||||
assertAccessIsDenied(user, "POST", "/" + index + "/_refresh");
|
assertAccessIsDenied(user, "POST", "/" + index + "/_refresh");
|
||||||
ImmutableMap<String, String> analyzeParams = ImmutableMap.of("text", "test");
|
Map<String, String> analyzeParams = singletonMap("text", "test");
|
||||||
assertAccessIsDenied(user, "GET", "/" + index + "/_analyze", null, analyzeParams);
|
assertAccessIsDenied(user, "GET", "/" + index + "/_analyze", null, analyzeParams);
|
||||||
assertAccessIsDenied(user, "POST", "/" + index + "/_flush");
|
assertAccessIsDenied(user, "POST", "/" + index + "/_flush");
|
||||||
assertAccessIsDenied(user, "POST", "/" + index + "/_optimize");
|
assertAccessIsDenied(user, "POST", "/" + index + "/_optimize");
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.shield.authc.esusers;
|
package org.elasticsearch.shield.authc.esusers;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.common.logging.ESLogger;
|
import org.elasticsearch.common.logging.ESLogger;
|
||||||
import org.elasticsearch.common.logging.ESLoggerFactory;
|
import org.elasticsearch.common.logging.ESLoggerFactory;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
@ -20,7 +19,6 @@ import org.elasticsearch.threadpool.ThreadPool;
|
||||||
import org.elasticsearch.watcher.ResourceWatcherService;
|
import org.elasticsearch.watcher.ResourceWatcherService;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import java.io.BufferedWriter;
|
import java.io.BufferedWriter;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
@ -35,9 +33,17 @@ import java.util.Map;
|
||||||
import java.util.concurrent.CountDownLatch;
|
import java.util.concurrent.CountDownLatch;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
import static org.mockito.Mockito.contains;
|
import static org.hamcrest.Matchers.empty;
|
||||||
import static org.mockito.Mockito.*;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.hasSize;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
|
import static org.mockito.Matchers.contains;
|
||||||
|
import static org.mockito.Matchers.eq;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.times;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -63,7 +69,6 @@ public class FileUserPasswdStoreTests extends ESTestCase {
|
||||||
terminate(threadPool);
|
terminate(threadPool);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testStore_ConfiguredWithUnreadableFile() throws Exception {
|
public void testStore_ConfiguredWithUnreadableFile() throws Exception {
|
||||||
|
|
||||||
Path file = createTempFile();
|
Path file = createTempFile();
|
||||||
|
@ -81,7 +86,6 @@ public class FileUserPasswdStoreTests extends ESTestCase {
|
||||||
assertThat(store.usersCount(), is(0));
|
assertThat(store.usersCount(), is(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testStore_AutoReload() throws Exception {
|
public void testStore_AutoReload() throws Exception {
|
||||||
Path users = getDataPath("users");
|
Path users = getDataPath("users");
|
||||||
Path tmp = createTempFile();
|
Path tmp = createTempFile();
|
||||||
|
@ -121,7 +125,6 @@ public class FileUserPasswdStoreTests extends ESTestCase {
|
||||||
assertThat(store.verifyPassword("foobar", SecuredStringTests.build("barfoo")), is(true));
|
assertThat(store.verifyPassword("foobar", SecuredStringTests.build("barfoo")), is(true));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testStore_AutoReload_WithParseFailures() throws Exception {
|
public void testStore_AutoReload_WithParseFailures() throws Exception {
|
||||||
Path users = getDataPath("users");
|
Path users = getDataPath("users");
|
||||||
Path tmp = createTempFile();
|
Path tmp = createTempFile();
|
||||||
|
@ -157,7 +160,6 @@ public class FileUserPasswdStoreTests extends ESTestCase {
|
||||||
assertThat(store.usersCount(), is(0));
|
assertThat(store.usersCount(), is(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFile() throws Exception {
|
public void testParseFile() throws Exception {
|
||||||
Path path = getDataPath("users");
|
Path path = getDataPath("users");
|
||||||
Map<String, char[]> users = FileUserPasswdStore.parseFile(path, null);
|
Map<String, char[]> users = FileUserPasswdStore.parseFile(path, null);
|
||||||
|
@ -177,17 +179,15 @@ public class FileUserPasswdStoreTests extends ESTestCase {
|
||||||
assertThat(new String(users.get("sha")), equalTo("{SHA}cojt0Pw//L6ToM8G41aOKFIWh7w="));
|
assertThat(new String(users.get("sha")), equalTo("{SHA}cojt0Pw//L6ToM8G41aOKFIWh7w="));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFile_Empty() throws Exception {
|
public void testParseFile_Empty() throws Exception {
|
||||||
Path empty = createTempFile();
|
Path empty = createTempFile();
|
||||||
ESLogger log = ESLoggerFactory.getLogger("test");
|
ESLogger log = ESLoggerFactory.getLogger("test");
|
||||||
log = spy(log);
|
log = spy(log);
|
||||||
ImmutableMap<String, char[]> users = FileUserPasswdStore.parseFile(empty, log);
|
Map<String, char[]> users = FileUserPasswdStore.parseFile(empty, log);
|
||||||
assertThat(users.isEmpty(), is(true));
|
assertThat(users.isEmpty(), is(true));
|
||||||
verify(log, times(1)).warn(contains("no users found"), eq(empty));
|
verify(log, times(1)).warn(contains("no users found"), eq(empty));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFile_WhenFileDoesNotExist() throws Exception {
|
public void testParseFile_WhenFileDoesNotExist() throws Exception {
|
||||||
Path file = createTempDir().resolve(randomAsciiOfLength(10));
|
Path file = createTempDir().resolve(randomAsciiOfLength(10));
|
||||||
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
||||||
|
@ -196,7 +196,6 @@ public class FileUserPasswdStoreTests extends ESTestCase {
|
||||||
assertThat(users.isEmpty(), is(true));
|
assertThat(users.isEmpty(), is(true));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFile_WhenCannotReadFile() throws Exception {
|
public void testParseFile_WhenCannotReadFile() throws Exception {
|
||||||
Path file = createTempFile();
|
Path file = createTempFile();
|
||||||
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
||||||
|
@ -210,7 +209,6 @@ public class FileUserPasswdStoreTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFile_InvalidLineDoesNotResultInLoggerNPE() throws Exception {
|
public void testParseFile_InvalidLineDoesNotResultInLoggerNPE() throws Exception {
|
||||||
Path file = createTempFile();
|
Path file = createTempFile();
|
||||||
Files.write(file, Arrays.asList("NotValidUsername=Password", "user:pass"), StandardCharsets.UTF_8);
|
Files.write(file, Arrays.asList("NotValidUsername=Password", "user:pass"), StandardCharsets.UTF_8);
|
||||||
|
@ -219,7 +217,6 @@ public class FileUserPasswdStoreTests extends ESTestCase {
|
||||||
assertThat(users.keySet(), hasSize(1));
|
assertThat(users.keySet(), hasSize(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFileLenient_WhenCannotReadFile() throws Exception {
|
public void testParseFileLenient_WhenCannotReadFile() throws Exception {
|
||||||
Path file = createTempFile();
|
Path file = createTempFile();
|
||||||
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
||||||
|
@ -233,7 +230,6 @@ public class FileUserPasswdStoreTests extends ESTestCase {
|
||||||
assertThat(msgs.get(0).text, containsString("failed to parse users file"));
|
assertThat(msgs.get(0).text, containsString("failed to parse users file"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFileWithLineWithEmptyPasswordAndWhitespace() throws Exception {
|
public void testParseFileWithLineWithEmptyPasswordAndWhitespace() throws Exception {
|
||||||
Path file = createTempFile();
|
Path file = createTempFile();
|
||||||
Files.write(file, Collections.singletonList("user: "), StandardCharsets.UTF_8);
|
Files.write(file, Collections.singletonList("user: "), StandardCharsets.UTF_8);
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.shield.authc.support;
|
package org.elasticsearch.shield.authc.support;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import com.unboundid.ldap.sdk.DN;
|
import com.unboundid.ldap.sdk.DN;
|
||||||
|
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.env.Environment;
|
import org.elasticsearch.env.Environment;
|
||||||
import org.elasticsearch.shield.audit.logfile.CapturingLogger;
|
import org.elasticsearch.shield.audit.logfile.CapturingLogger;
|
||||||
|
@ -18,7 +18,6 @@ import org.elasticsearch.threadpool.ThreadPool;
|
||||||
import org.elasticsearch.watcher.ResourceWatcherService;
|
import org.elasticsearch.watcher.ResourceWatcherService;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import java.io.BufferedWriter;
|
import java.io.BufferedWriter;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
@ -29,11 +28,20 @@ import java.nio.file.StandardOpenOption;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.concurrent.CountDownLatch;
|
import java.util.concurrent.CountDownLatch;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.contains;
|
||||||
|
import static org.hamcrest.Matchers.containsInAnyOrder;
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.hasItem;
|
||||||
|
import static org.hamcrest.Matchers.hasItems;
|
||||||
|
import static org.hamcrest.Matchers.hasKey;
|
||||||
|
import static org.hamcrest.Matchers.hasSize;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -70,7 +78,6 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
terminate(threadPool);
|
terminate(threadPool);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testMapper_ConfiguredWithUnreadableFile() throws Exception {
|
public void testMapper_ConfiguredWithUnreadableFile() throws Exception {
|
||||||
Path file = createTempFile();
|
Path file = createTempFile();
|
||||||
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
||||||
|
@ -81,7 +88,6 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
assertThat(mapper.mappingsCount(), is(0));
|
assertThat(mapper.mappingsCount(), is(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testMapper_AutoReload() throws Exception {
|
public void testMapper_AutoReload() throws Exception {
|
||||||
Path roleMappingFile = getDataPath("role_mapping.yml");
|
Path roleMappingFile = getDataPath("role_mapping.yml");
|
||||||
Path file = env.binFile().getParent().resolve("test_role_mapping.yml");
|
Path file = env.binFile().getParent().resolve("test_role_mapping.yml");
|
||||||
|
@ -121,7 +127,6 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
assertThat(roles, contains("fantastic_four"));
|
assertThat(roles, contains("fantastic_four"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testMapper_AutoReload_WithParseFailures() throws Exception {
|
public void testMapper_AutoReload_WithParseFailures() throws Exception {
|
||||||
Path roleMappingFile = getDataPath("role_mapping.yml");
|
Path roleMappingFile = getDataPath("role_mapping.yml");
|
||||||
Path file = env.binFile().getParent().resolve("test_role_mapping.yml");
|
Path file = env.binFile().getParent().resolve("test_role_mapping.yml");
|
||||||
|
@ -155,11 +160,10 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
assertThat(mapper.mappingsCount(), is(0));
|
assertThat(mapper.mappingsCount(), is(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFile() throws Exception {
|
public void testParseFile() throws Exception {
|
||||||
Path file = getDataPath("role_mapping.yml");
|
Path file = getDataPath("role_mapping.yml");
|
||||||
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
||||||
ImmutableMap<DN, Set<String>> mappings = DnRoleMapper.parseFile(file, logger, "_type", "_name");
|
Map<DN, Set<String>> mappings = DnRoleMapper.parseFile(file, logger, "_type", "_name");
|
||||||
assertThat(mappings, notNullValue());
|
assertThat(mappings, notNullValue());
|
||||||
assertThat(mappings.size(), is(3));
|
assertThat(mappings.size(), is(3));
|
||||||
|
|
||||||
|
@ -185,11 +189,10 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
assertThat(roles, contains("avenger"));
|
assertThat(roles, contains("avenger"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFile_Empty() throws Exception {
|
public void testParseFile_Empty() throws Exception {
|
||||||
Path file = createTempFile();
|
Path file = createTempFile();
|
||||||
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
||||||
ImmutableMap<DN, Set<String>> mappings = DnRoleMapper.parseFile(file, logger, "_type", "_name");
|
Map<DN, Set<String>> mappings = DnRoleMapper.parseFile(file, logger, "_type", "_name");
|
||||||
assertThat(mappings, notNullValue());
|
assertThat(mappings, notNullValue());
|
||||||
assertThat(mappings.isEmpty(), is(true));
|
assertThat(mappings.isEmpty(), is(true));
|
||||||
List<CapturingLogger.Msg> msgs = logger.output(CapturingLogger.Level.WARN);
|
List<CapturingLogger.Msg> msgs = logger.output(CapturingLogger.Level.WARN);
|
||||||
|
@ -197,16 +200,14 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
assertThat(msgs.get(0).text, containsString("no mappings found"));
|
assertThat(msgs.get(0).text, containsString("no mappings found"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFile_WhenFileDoesNotExist() throws Exception {
|
public void testParseFile_WhenFileDoesNotExist() throws Exception {
|
||||||
Path file = createTempDir().resolve(randomAsciiOfLength(10));
|
Path file = createTempDir().resolve(randomAsciiOfLength(10));
|
||||||
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
||||||
ImmutableMap<DN, Set<String>> mappings = DnRoleMapper.parseFile(file, logger, "_type", "_name");
|
Map<DN, Set<String>> mappings = DnRoleMapper.parseFile(file, logger, "_type", "_name");
|
||||||
assertThat(mappings, notNullValue());
|
assertThat(mappings, notNullValue());
|
||||||
assertThat(mappings.isEmpty(), is(true));
|
assertThat(mappings.isEmpty(), is(true));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFile_WhenCannotReadFile() throws Exception {
|
public void testParseFile_WhenCannotReadFile() throws Exception {
|
||||||
Path file = createTempFile();
|
Path file = createTempFile();
|
||||||
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
||||||
|
@ -220,13 +221,12 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testParseFileLenient_WhenCannotReadFile() throws Exception {
|
public void testParseFileLenient_WhenCannotReadFile() throws Exception {
|
||||||
Path file = createTempFile();
|
Path file = createTempFile();
|
||||||
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
// writing in utf_16 should cause a parsing error as we try to read the file in utf_8
|
||||||
Files.write(file, Collections.singletonList("aldlfkjldjdflkjd"), StandardCharsets.UTF_16);
|
Files.write(file, Collections.singletonList("aldlfkjldjdflkjd"), StandardCharsets.UTF_16);
|
||||||
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
CapturingLogger logger = new CapturingLogger(CapturingLogger.Level.INFO);
|
||||||
ImmutableMap<DN, Set<String>> mappings = DnRoleMapper.parseFileLenient(file, logger, "_type", "_name");
|
Map<DN, Set<String>> mappings = DnRoleMapper.parseFileLenient(file, logger, "_type", "_name");
|
||||||
assertThat(mappings, notNullValue());
|
assertThat(mappings, notNullValue());
|
||||||
assertThat(mappings.isEmpty(), is(true));
|
assertThat(mappings.isEmpty(), is(true));
|
||||||
List<CapturingLogger.Msg> msgs = logger.output(CapturingLogger.Level.ERROR);
|
List<CapturingLogger.Msg> msgs = logger.output(CapturingLogger.Level.ERROR);
|
||||||
|
@ -234,7 +234,6 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
assertThat(msgs.get(0).text, containsString("failed to parse role mappings file"));
|
assertThat(msgs.get(0).text, containsString("failed to parse role mappings file"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testYaml() throws Exception {
|
public void testYaml() throws Exception {
|
||||||
Path file = getDataPath("role_mapping.yml");
|
Path file = getDataPath("role_mapping.yml");
|
||||||
Settings ldapSettings = Settings.settingsBuilder()
|
Settings ldapSettings = Settings.settingsBuilder()
|
||||||
|
@ -250,7 +249,6 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
assertThat(roles, hasItems("shield", "avenger"));
|
assertThat(roles, hasItems("shield", "avenger"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRelativeDN() {
|
public void testRelativeDN() {
|
||||||
Settings ldapSettings = Settings.builder()
|
Settings ldapSettings = Settings.builder()
|
||||||
.put(DnRoleMapper.USE_UNMAPPED_GROUPS_AS_ROLES_SETTING, true)
|
.put(DnRoleMapper.USE_UNMAPPED_GROUPS_AS_ROLES_SETTING, true)
|
||||||
|
@ -263,7 +261,6 @@ public class DnRoleMapperTests extends ESTestCase {
|
||||||
assertThat(roles, hasItems("genius", "billionaire", "playboy", "philanthropist", "shield", "avengers"));
|
assertThat(roles, hasItems("genius", "billionaire", "playboy", "philanthropist", "shield", "avengers"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testUserDNMapping() throws Exception {
|
public void testUserDNMapping() throws Exception {
|
||||||
Path file = getDataPath("role_mapping.yml");
|
Path file = getDataPath("role_mapping.yml");
|
||||||
Settings ldapSettings = Settings.builder()
|
Settings ldapSettings = Settings.builder()
|
||||||
|
|
|
@ -5,8 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.shield.authz.accesscontrol;
|
package org.elasticsearch.shield.authz.accesscontrol;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.apache.lucene.analysis.standard.StandardAnalyzer;
|
import org.apache.lucene.analysis.standard.StandardAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
|
@ -51,6 +49,7 @@ import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
|
||||||
import static java.util.Collections.singleton;
|
import static java.util.Collections.singleton;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.mockito.Matchers.any;
|
import static org.mockito.Matchers.any;
|
||||||
import static org.mockito.Matchers.anyBoolean;
|
import static org.mockito.Matchers.anyBoolean;
|
||||||
|
@ -76,7 +75,7 @@ public class ShieldIndexSearcherWrapperIntegrationTests extends ESTestCase {
|
||||||
TransportRequest request = new TransportRequest.Empty();
|
TransportRequest request = new TransportRequest.Empty();
|
||||||
RequestContext.setCurrent(new RequestContext(request));
|
RequestContext.setCurrent(new RequestContext(request));
|
||||||
IndicesAccessControl.IndexAccessControl indexAccessControl = new IndicesAccessControl.IndexAccessControl(true, null, singleton(new BytesArray("{}")));
|
IndicesAccessControl.IndexAccessControl indexAccessControl = new IndicesAccessControl.IndexAccessControl(true, null, singleton(new BytesArray("{}")));
|
||||||
request.putInContext(InternalAuthorizationService.INDICES_PERMISSIONS_KEY, new IndicesAccessControl(true, ImmutableMap.of("_index", indexAccessControl)));
|
request.putInContext(InternalAuthorizationService.INDICES_PERMISSIONS_KEY, new IndicesAccessControl(true, singletonMap("_index", indexAccessControl)));
|
||||||
IndexQueryParserService parserService = mock(IndexQueryParserService.class);
|
IndexQueryParserService parserService = mock(IndexQueryParserService.class);
|
||||||
|
|
||||||
IndicesLifecycle indicesLifecycle = mock(IndicesLifecycle.class);
|
IndicesLifecycle indicesLifecycle = mock(IndicesLifecycle.class);
|
||||||
|
|
|
@ -5,8 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.shield.authz.accesscontrol;
|
package org.elasticsearch.shield.authz.accesscontrol;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.apache.lucene.analysis.standard.StandardAnalyzer;
|
import org.apache.lucene.analysis.standard.StandardAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
|
@ -59,6 +57,7 @@ import java.io.IOException;
|
||||||
|
|
||||||
import static java.util.Collections.emptySet;
|
import static java.util.Collections.emptySet;
|
||||||
import static java.util.Collections.singleton;
|
import static java.util.Collections.singleton;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.shield.authz.accesscontrol.ShieldIndexSearcherWrapper.intersectScorerAndRoleBits;
|
import static org.elasticsearch.shield.authz.accesscontrol.ShieldIndexSearcherWrapper.intersectScorerAndRoleBits;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
@ -114,7 +113,7 @@ public class ShieldIndexSearcherWrapperUnitTests extends ESTestCase {
|
||||||
mapperService.merge("type", new CompressedXContent(mappingSource.string()), false, false);
|
mapperService.merge("type", new CompressedXContent(mappingSource.string()), false, false);
|
||||||
|
|
||||||
IndicesAccessControl.IndexAccessControl indexAccessControl = new IndicesAccessControl.IndexAccessControl(true, emptySet(), null);
|
IndicesAccessControl.IndexAccessControl indexAccessControl = new IndicesAccessControl.IndexAccessControl(true, emptySet(), null);
|
||||||
request.putInContext(InternalAuthorizationService.INDICES_PERMISSIONS_KEY, new IndicesAccessControl(true, ImmutableMap.of("_index", indexAccessControl)));
|
request.putInContext(InternalAuthorizationService.INDICES_PERMISSIONS_KEY, new IndicesAccessControl(true, singletonMap("_index", indexAccessControl)));
|
||||||
|
|
||||||
FieldSubsetReader.FieldSubsetDirectoryReader result = (FieldSubsetReader.FieldSubsetDirectoryReader) shieldIndexSearcherWrapper.wrap(esIn);
|
FieldSubsetReader.FieldSubsetDirectoryReader result = (FieldSubsetReader.FieldSubsetDirectoryReader) shieldIndexSearcherWrapper.wrap(esIn);
|
||||||
assertThat(result.getFieldNames().size(), equalTo(11));
|
assertThat(result.getFieldNames().size(), equalTo(11));
|
||||||
|
@ -324,7 +323,7 @@ public class ShieldIndexSearcherWrapperUnitTests extends ESTestCase {
|
||||||
|
|
||||||
private void assertResolvedFields(String expression, String... expectedFields) {
|
private void assertResolvedFields(String expression, String... expectedFields) {
|
||||||
IndicesAccessControl.IndexAccessControl indexAccessControl = new IndicesAccessControl.IndexAccessControl(true, singleton(expression), null);
|
IndicesAccessControl.IndexAccessControl indexAccessControl = new IndicesAccessControl.IndexAccessControl(true, singleton(expression), null);
|
||||||
request.putInContext(InternalAuthorizationService.INDICES_PERMISSIONS_KEY, new IndicesAccessControl(true, ImmutableMap.of("_index", indexAccessControl)));
|
request.putInContext(InternalAuthorizationService.INDICES_PERMISSIONS_KEY, new IndicesAccessControl(true, singletonMap("_index", indexAccessControl)));
|
||||||
FieldSubsetReader.FieldSubsetDirectoryReader result = (FieldSubsetReader.FieldSubsetDirectoryReader) shieldIndexSearcherWrapper.wrap(esIn);
|
FieldSubsetReader.FieldSubsetDirectoryReader result = (FieldSubsetReader.FieldSubsetDirectoryReader) shieldIndexSearcherWrapper.wrap(esIn);
|
||||||
assertThat(result.getFieldNames().size() - shieldIndexSearcherWrapper.getAllowedMetaFields().size(), equalTo(expectedFields.length));
|
assertThat(result.getFieldNames().size() - shieldIndexSearcherWrapper.getAllowedMetaFields().size(), equalTo(expectedFields.length));
|
||||||
for (String expectedField : expectedFields) {
|
for (String expectedField : expectedFields) {
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.shield.transport;
|
package org.elasticsearch.shield.transport;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.Version;
|
import org.elasticsearch.Version;
|
||||||
import org.elasticsearch.common.network.NetworkAddress;
|
import org.elasticsearch.common.network.NetworkAddress;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
@ -29,6 +28,7 @@ import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.settings.Settings.settingsBuilder;
|
import static org.elasticsearch.common.settings.Settings.settingsBuilder;
|
||||||
import static org.elasticsearch.shield.test.ShieldTestUtils.createFolder;
|
import static org.elasticsearch.shield.test.ShieldTestUtils.createFolder;
|
||||||
import static org.elasticsearch.shield.test.ShieldTestUtils.writeFile;
|
import static org.elasticsearch.shield.test.ShieldTestUtils.writeFile;
|
||||||
|
@ -151,7 +151,7 @@ public class ServerTransportFilterIntegrationTests extends ShieldIntegTestCase {
|
||||||
// wait for a timeout, because as long as the node is not connected to the cluster
|
// wait for a timeout, because as long as the node is not connected to the cluster
|
||||||
// the license is disabled and therefore blocking health & stats calls.
|
// the license is disabled and therefore blocking health & stats calls.
|
||||||
node.client().admin().cluster().prepareUpdateSettings()
|
node.client().admin().cluster().prepareUpdateSettings()
|
||||||
.setTransientSettings(ImmutableMap.of("key", "value"))
|
.setTransientSettings(singletonMap("key", "value"))
|
||||||
.setMasterNodeTimeout(TimeValue.timeValueSeconds(2))
|
.setMasterNodeTimeout(TimeValue.timeValueSeconds(2))
|
||||||
.get();
|
.get();
|
||||||
fail("Expected to fail update settings as the node should not be able to connect to the cluster, and therefore there should be no master");
|
fail("Expected to fail update settings as the node should not be able to connect to the cluster, and therefore there should be no master");
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.actions;
|
package org.elasticsearch.watcher.actions;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.inject.Inject;
|
import org.elasticsearch.common.inject.Inject;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
@ -23,14 +22,14 @@ import java.util.Map;
|
||||||
*/
|
*/
|
||||||
public class ActionRegistry {
|
public class ActionRegistry {
|
||||||
|
|
||||||
private final ImmutableMap<String, ActionFactory> parsers;
|
private final Map<String, ActionFactory> parsers;
|
||||||
private final TransformRegistry transformRegistry;
|
private final TransformRegistry transformRegistry;
|
||||||
private final Clock clock;
|
private final Clock clock;
|
||||||
private final LicenseService licenseService;
|
private final LicenseService licenseService;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public ActionRegistry(Map<String, ActionFactory> parsers, TransformRegistry transformRegistry, Clock clock, LicenseService licenseService) {
|
public ActionRegistry(Map<String, ActionFactory> parsers, TransformRegistry transformRegistry, Clock clock, LicenseService licenseService) {
|
||||||
this.parsers = ImmutableMap.copyOf(parsers);
|
this.parsers = parsers;
|
||||||
this.transformRegistry = transformRegistry;
|
this.transformRegistry = transformRegistry;
|
||||||
this.clock = clock;
|
this.clock = clock;
|
||||||
this.licenseService = licenseService;
|
this.licenseService = licenseService;
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.condition;
|
package org.elasticsearch.watcher.condition;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.inject.Inject;
|
import org.elasticsearch.common.inject.Inject;
|
||||||
import org.elasticsearch.common.xcontent.ToXContent;
|
import org.elasticsearch.common.xcontent.ToXContent;
|
||||||
|
@ -21,11 +20,11 @@ import java.util.Set;
|
||||||
*/
|
*/
|
||||||
public class ConditionRegistry {
|
public class ConditionRegistry {
|
||||||
|
|
||||||
private final ImmutableMap<String, ConditionFactory> factories;
|
private final Map<String, ConditionFactory> factories;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public ConditionRegistry(Map<String, ConditionFactory> factories) {
|
public ConditionRegistry(Map<String, ConditionFactory> factories) {
|
||||||
this.factories = ImmutableMap.copyOf(factories);
|
this.factories = factories;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Set<String> types() {
|
public Set<String> types() {
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.input;
|
package org.elasticsearch.watcher.input;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.inject.Inject;
|
import org.elasticsearch.common.inject.Inject;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
@ -18,11 +17,11 @@ import java.util.Map;
|
||||||
*/
|
*/
|
||||||
public class InputRegistry {
|
public class InputRegistry {
|
||||||
|
|
||||||
private final ImmutableMap<String, InputFactory> factories;
|
private final Map<String, InputFactory> factories;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public InputRegistry(Map<String, InputFactory> factories) {
|
public InputRegistry(Map<String, InputFactory> factories) {
|
||||||
this.factories = ImmutableMap.copyOf(factories);
|
this.factories = factories;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -5,15 +5,12 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.support;
|
package org.elasticsearch.watcher.support;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.elasticsearch.action.admin.indices.template.put.PutIndexTemplateRequest;
|
import org.elasticsearch.action.admin.indices.template.put.PutIndexTemplateRequest;
|
||||||
import org.elasticsearch.action.admin.indices.template.put.PutIndexTemplateResponse;
|
import org.elasticsearch.action.admin.indices.template.put.PutIndexTemplateResponse;
|
||||||
import org.elasticsearch.cluster.ClusterChangedEvent;
|
import org.elasticsearch.cluster.ClusterChangedEvent;
|
||||||
import org.elasticsearch.cluster.ClusterService;
|
import org.elasticsearch.cluster.ClusterService;
|
||||||
import org.elasticsearch.cluster.ClusterState;
|
import org.elasticsearch.cluster.ClusterState;
|
||||||
import org.elasticsearch.cluster.ClusterStateListener;
|
import org.elasticsearch.cluster.ClusterStateListener;
|
||||||
import org.elasticsearch.common.collect.MapBuilder;
|
|
||||||
import org.elasticsearch.common.component.AbstractComponent;
|
import org.elasticsearch.common.component.AbstractComponent;
|
||||||
import org.elasticsearch.common.inject.Inject;
|
import org.elasticsearch.common.inject.Inject;
|
||||||
import org.elasticsearch.common.io.Streams;
|
import org.elasticsearch.common.io.Streams;
|
||||||
|
@ -26,11 +23,13 @@ import org.elasticsearch.watcher.support.init.proxy.ClientProxy;
|
||||||
import org.elasticsearch.watcher.watch.WatchStore;
|
import org.elasticsearch.watcher.watch.WatchStore;
|
||||||
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.concurrent.Executor;
|
import java.util.concurrent.Executor;
|
||||||
|
|
||||||
|
import static java.util.Collections.unmodifiableMap;
|
||||||
import static java.util.Collections.unmodifiableSet;
|
import static java.util.Collections.unmodifiableSet;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -43,7 +42,7 @@ public class WatcherIndexTemplateRegistry extends AbstractComponent implements C
|
||||||
private final ClusterService clusterService;
|
private final ClusterService clusterService;
|
||||||
private final Set<TemplateConfig> indexTemplates;
|
private final Set<TemplateConfig> indexTemplates;
|
||||||
|
|
||||||
private volatile ImmutableMap<String, Settings> customIndexSettings;
|
private volatile Map<String, Settings> customIndexSettings;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public WatcherIndexTemplateRegistry(Settings settings, NodeSettingsService nodeSettingsService, ClusterService clusterService,
|
public WatcherIndexTemplateRegistry(Settings settings, NodeSettingsService nodeSettingsService, ClusterService clusterService,
|
||||||
|
@ -56,12 +55,12 @@ public class WatcherIndexTemplateRegistry extends AbstractComponent implements C
|
||||||
clusterService.add(this);
|
clusterService.add(this);
|
||||||
nodeSettingsService.addListener(this);
|
nodeSettingsService.addListener(this);
|
||||||
|
|
||||||
ImmutableMap.Builder<String, Settings> customIndexSettingsBuilder = ImmutableMap.builder();
|
Map<String, Settings> customIndexSettings = new HashMap<>();
|
||||||
for (TemplateConfig indexTemplate : indexTemplates) {
|
for (TemplateConfig indexTemplate : indexTemplates) {
|
||||||
Settings customSettings = this.settings.getAsSettings(indexTemplate.getSettingsPrefix());
|
Settings customSettings = this.settings.getAsSettings(indexTemplate.getSettingsPrefix());
|
||||||
customIndexSettings = customIndexSettingsBuilder.put(indexTemplate.getSettingsPrefix(), customSettings).build();
|
customIndexSettings.put(indexTemplate.getSettingsPrefix(), customSettings);
|
||||||
}
|
}
|
||||||
customIndexSettings = customIndexSettingsBuilder.build();
|
this.customIndexSettings = unmodifiableMap(customIndexSettings);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -142,9 +141,9 @@ public class WatcherIndexTemplateRegistry extends AbstractComponent implements C
|
||||||
}
|
}
|
||||||
|
|
||||||
if (changed) {
|
if (changed) {
|
||||||
customIndexSettings = MapBuilder.newMapBuilder(customIndexSettings)
|
Map<String, Settings> customIndexSettings = new HashMap<String, Settings>(this.customIndexSettings);
|
||||||
.put(config.getSettingsPrefix(), builder.build())
|
customIndexSettings.put(config.getSettingsPrefix(), builder.build());
|
||||||
.immutableMap();
|
this.customIndexSettings = customIndexSettings;
|
||||||
putTemplate(config, false);
|
putTemplate(config, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.support.http;
|
package org.elasticsearch.watcher.support.http;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.Nullable;
|
import org.elasticsearch.common.Nullable;
|
||||||
import org.elasticsearch.common.ParseFieldMatcher;
|
import org.elasticsearch.common.ParseFieldMatcher;
|
||||||
|
@ -24,11 +23,12 @@ import org.elasticsearch.watcher.support.text.TextTemplateEngine;
|
||||||
import org.jboss.netty.handler.codec.http.HttpHeaders;
|
import org.jboss.netty.handler.codec.http.HttpHeaders;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import static java.util.Collections.emptyMap;
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
|
import static java.util.Collections.unmodifiableMap;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
|
@ -54,8 +54,8 @@ public class HttpRequestTemplate implements ToXContent {
|
||||||
this.scheme = scheme != null ? scheme :Scheme.HTTP;
|
this.scheme = scheme != null ? scheme :Scheme.HTTP;
|
||||||
this.method = method != null ? method : HttpMethod.GET;
|
this.method = method != null ? method : HttpMethod.GET;
|
||||||
this.path = path;
|
this.path = path;
|
||||||
this.params = params != null ? ImmutableMap.copyOf(params) : emptyMap();
|
this.params = params != null ? params : emptyMap();
|
||||||
this.headers = headers != null ? ImmutableMap.copyOf(headers) : emptyMap();
|
this.headers = headers != null ? headers : emptyMap();
|
||||||
this.auth = auth;
|
this.auth = auth;
|
||||||
this.body = body;
|
this.body = body;
|
||||||
this.connectionTimeout = connectionTimeout;
|
this.connectionTimeout = connectionTimeout;
|
||||||
|
@ -121,7 +121,7 @@ public class HttpRequestTemplate implements ToXContent {
|
||||||
request.setParams(mapBuilder.map());
|
request.setParams(mapBuilder.map());
|
||||||
}
|
}
|
||||||
if ((headers == null || headers.isEmpty()) && body != null && body.getContentType() != null) {
|
if ((headers == null || headers.isEmpty()) && body != null && body.getContentType() != null) {
|
||||||
request.setHeaders(ImmutableMap.of(HttpHeaders.Names.CONTENT_TYPE, body.getContentType().restContentType()));
|
request.setHeaders(singletonMap(HttpHeaders.Names.CONTENT_TYPE, body.getContentType().restContentType()));
|
||||||
} else if (headers != null && !headers.isEmpty()) {
|
} else if (headers != null && !headers.isEmpty()) {
|
||||||
MapBuilder<String, String> mapBuilder = MapBuilder.newMapBuilder();
|
MapBuilder<String, String> mapBuilder = MapBuilder.newMapBuilder();
|
||||||
if (body != null && body.getContentType() != null) {
|
if (body != null && body.getContentType() != null) {
|
||||||
|
@ -148,6 +148,7 @@ public class HttpRequestTemplate implements ToXContent {
|
||||||
return request.build();
|
return request.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public XContentBuilder toXContent(XContentBuilder builder, ToXContent.Params params) throws IOException {
|
public XContentBuilder toXContent(XContentBuilder builder, ToXContent.Params params) throws IOException {
|
||||||
builder.startObject();
|
builder.startObject();
|
||||||
builder.field(Field.SCHEME.getPreferredName(), scheme, params);
|
builder.field(Field.SCHEME.getPreferredName(), scheme, params);
|
||||||
|
@ -334,8 +335,8 @@ public class HttpRequestTemplate implements ToXContent {
|
||||||
private Scheme scheme;
|
private Scheme scheme;
|
||||||
private HttpMethod method;
|
private HttpMethod method;
|
||||||
private TextTemplate path;
|
private TextTemplate path;
|
||||||
private final ImmutableMap.Builder<String, TextTemplate> params = ImmutableMap.builder();
|
private final Map<String, TextTemplate> params = new HashMap<>();
|
||||||
private final ImmutableMap.Builder<String, TextTemplate> headers = ImmutableMap.builder();
|
private final Map<String, TextTemplate> headers = new HashMap<>();
|
||||||
private HttpAuth auth;
|
private HttpAuth auth;
|
||||||
private TextTemplate body;
|
private TextTemplate body;
|
||||||
private TimeValue connectionTimeout;
|
private TimeValue connectionTimeout;
|
||||||
|
@ -433,7 +434,8 @@ public class HttpRequestTemplate implements ToXContent {
|
||||||
}
|
}
|
||||||
|
|
||||||
public HttpRequestTemplate build() {
|
public HttpRequestTemplate build() {
|
||||||
return new HttpRequestTemplate(host, port, scheme, method, path, params.build(), headers.build(), auth, body, connectionTimeout, readTimeout);
|
return new HttpRequestTemplate(host, port, scheme, method, path, unmodifiableMap(new HashMap<>(params)),
|
||||||
|
unmodifiableMap(new HashMap<>(headers)), auth, body, connectionTimeout, readTimeout);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.support.http;
|
package org.elasticsearch.watcher.support.http;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.ParseField;
|
import org.elasticsearch.common.ParseField;
|
||||||
import org.elasticsearch.common.ParseFieldMatcher;
|
import org.elasticsearch.common.ParseFieldMatcher;
|
||||||
|
@ -17,17 +16,18 @@ import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.common.xcontent.XContentType;
|
import org.elasticsearch.common.xcontent.XContentType;
|
||||||
import org.jboss.netty.handler.codec.http.HttpHeaders;
|
import org.jboss.netty.handler.codec.http.HttpHeaders;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
|
||||||
|
|
||||||
import static java.util.Collections.emptyMap;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static java.util.Collections.unmodifiableMap;
|
||||||
|
|
||||||
public class HttpResponse implements ToXContent {
|
public class HttpResponse implements ToXContent {
|
||||||
|
|
||||||
private final int status;
|
private final int status;
|
||||||
|
@ -51,7 +51,7 @@ public class HttpResponse implements ToXContent {
|
||||||
}
|
}
|
||||||
|
|
||||||
public HttpResponse(int status, @Nullable byte[] body) {
|
public HttpResponse(int status, @Nullable byte[] body) {
|
||||||
this(status, body != null ? new BytesArray(body) : null, ImmutableMap.<String, String[]>of());
|
this(status, body != null ? new BytesArray(body) : null, emptyMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
public HttpResponse(int status, @Nullable byte[] body, Map<String, String[]> headers) {
|
public HttpResponse(int status, @Nullable byte[] body, Map<String, String[]> headers) {
|
||||||
|
@ -160,7 +160,7 @@ public class HttpResponse implements ToXContent {
|
||||||
|
|
||||||
int status = -1;
|
int status = -1;
|
||||||
String body = null;
|
String body = null;
|
||||||
ImmutableMap.Builder<String, String[]> headers = ImmutableMap.builder();
|
Map<String, String[]> headers = new HashMap<>();
|
||||||
|
|
||||||
String currentFieldName = null;
|
String currentFieldName = null;
|
||||||
XContentParser.Token token;
|
XContentParser.Token token;
|
||||||
|
@ -210,7 +210,7 @@ public class HttpResponse implements ToXContent {
|
||||||
if (status < 0) {
|
if (status < 0) {
|
||||||
throw new ElasticsearchParseException("could not parse http response. missing required numeric [{}] field holding the response's http status code", Field.STATUS.getPreferredName());
|
throw new ElasticsearchParseException("could not parse http response. missing required numeric [{}] field holding the response's http status code", Field.STATUS.getPreferredName());
|
||||||
}
|
}
|
||||||
return new HttpResponse(status, body, headers.build());
|
return new HttpResponse(status, body, unmodifiableMap(headers));
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Field {
|
interface Field {
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.support.http.auth;
|
package org.elasticsearch.watcher.support.http.auth;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.inject.Inject;
|
import org.elasticsearch.common.inject.Inject;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
@ -20,11 +19,11 @@ import static org.elasticsearch.watcher.support.Exceptions.illegalArgument;
|
||||||
*/
|
*/
|
||||||
public class HttpAuthRegistry {
|
public class HttpAuthRegistry {
|
||||||
|
|
||||||
private final ImmutableMap<String, HttpAuthFactory> factories;
|
private final Map<String, HttpAuthFactory> factories;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public HttpAuthRegistry(Map<String, HttpAuthFactory> factories) {
|
public HttpAuthRegistry(Map<String, HttpAuthFactory> factories) {
|
||||||
this.factories = ImmutableMap.copyOf(factories);
|
this.factories = factories;
|
||||||
}
|
}
|
||||||
|
|
||||||
public HttpAuth parse(XContentParser parser) throws IOException {
|
public HttpAuth parse(XContentParser parser) throws IOException {
|
||||||
|
|
|
@ -5,9 +5,14 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.support.xcontent;
|
package org.elasticsearch.watcher.support.xcontent;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.common.xcontent.ToXContent;
|
import org.elasticsearch.common.xcontent.ToXContent;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static java.util.Collections.unmodifiableMap;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -31,7 +36,7 @@ public class WatcherParams extends ToXContent.DelegatingMapParams {
|
||||||
return wrap(params).debug();
|
return wrap(params).debug();
|
||||||
}
|
}
|
||||||
|
|
||||||
private WatcherParams(ImmutableMap<String, String> params, ToXContent.Params delegate) {
|
private WatcherParams(Map<String, String> params, ToXContent.Params delegate) {
|
||||||
super(params, delegate);
|
super(params, delegate);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,7 +55,7 @@ public class WatcherParams extends ToXContent.DelegatingMapParams {
|
||||||
public static WatcherParams wrap(ToXContent.Params params) {
|
public static WatcherParams wrap(ToXContent.Params params) {
|
||||||
return params instanceof WatcherParams ?
|
return params instanceof WatcherParams ?
|
||||||
(WatcherParams) params :
|
(WatcherParams) params :
|
||||||
new WatcherParams(ImmutableMap.<String, String>of(), params);
|
new WatcherParams(emptyMap(), params);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Builder builder() {
|
public static Builder builder() {
|
||||||
|
@ -64,7 +69,7 @@ public class WatcherParams extends ToXContent.DelegatingMapParams {
|
||||||
public static class Builder {
|
public static class Builder {
|
||||||
|
|
||||||
private final ToXContent.Params delegate;
|
private final ToXContent.Params delegate;
|
||||||
private final ImmutableMap.Builder<String, String> params = ImmutableMap.builder();
|
private final Map<String, String> params = new HashMap<>();
|
||||||
|
|
||||||
private Builder(ToXContent.Params delegate) {
|
private Builder(ToXContent.Params delegate) {
|
||||||
this.delegate = delegate;
|
this.delegate = delegate;
|
||||||
|
@ -91,7 +96,7 @@ public class WatcherParams extends ToXContent.DelegatingMapParams {
|
||||||
}
|
}
|
||||||
|
|
||||||
public WatcherParams build() {
|
public WatcherParams build() {
|
||||||
return new WatcherParams(params.build(), delegate);
|
return new WatcherParams(unmodifiableMap(new HashMap<>(params)), delegate);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.transform;
|
package org.elasticsearch.watcher.transform;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.inject.Inject;
|
import org.elasticsearch.common.inject.Inject;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
@ -22,7 +21,7 @@ public class TransformRegistry {
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public TransformRegistry(Map<String, TransformFactory> factories) {
|
public TransformRegistry(Map<String, TransformFactory> factories) {
|
||||||
this.factories = ImmutableMap.copyOf(factories);
|
this.factories = factories;
|
||||||
}
|
}
|
||||||
|
|
||||||
public TransformFactory factory(String type) {
|
public TransformFactory factory(String type) {
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.trigger.schedule;
|
package org.elasticsearch.watcher.trigger.schedule;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.inject.Inject;
|
import org.elasticsearch.common.inject.Inject;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
@ -18,12 +17,11 @@ import java.util.Set;
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class ScheduleRegistry {
|
public class ScheduleRegistry {
|
||||||
|
private final Map<String, Schedule.Parser> parsers;
|
||||||
private final ImmutableMap<String, Schedule.Parser> parsers;
|
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public ScheduleRegistry(Map<String, Schedule.Parser> parsers) {
|
public ScheduleRegistry(Map<String, Schedule.Parser> parsers) {
|
||||||
this.parsers = ImmutableMap.copyOf(parsers);
|
this.parsers = parsers;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Set<String> types() {
|
public Set<String> types() {
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher;
|
package org.elasticsearch.watcher;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchTimeoutException;
|
import org.elasticsearch.ElasticsearchTimeoutException;
|
||||||
import org.elasticsearch.action.delete.DeleteResponse;
|
import org.elasticsearch.action.delete.DeleteResponse;
|
||||||
import org.elasticsearch.action.index.IndexResponse;
|
import org.elasticsearch.action.index.IndexResponse;
|
||||||
|
@ -15,7 +14,6 @@ import org.elasticsearch.common.bytes.BytesReference;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.watcher.actions.ActionStatus;
|
|
||||||
import org.elasticsearch.watcher.execution.ExecutionService;
|
import org.elasticsearch.watcher.execution.ExecutionService;
|
||||||
import org.elasticsearch.watcher.support.WatcherIndexTemplateRegistry;
|
import org.elasticsearch.watcher.support.WatcherIndexTemplateRegistry;
|
||||||
import org.elasticsearch.watcher.support.clock.ClockMock;
|
import org.elasticsearch.watcher.support.clock.ClockMock;
|
||||||
|
@ -32,13 +30,21 @@ import org.joda.time.DateTimeZone;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
import static org.hamcrest.Matchers.not;
|
import static org.hamcrest.Matchers.not;
|
||||||
import static org.hamcrest.Matchers.sameInstance;
|
import static org.hamcrest.Matchers.sameInstance;
|
||||||
import static org.mockito.Matchers.any;
|
import static org.mockito.Matchers.any;
|
||||||
import static org.mockito.Mockito.*;
|
import static org.mockito.Matchers.eq;
|
||||||
|
import static org.mockito.Mockito.doReturn;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.never;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.times;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.verifyZeroInteractions;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -219,7 +225,7 @@ public class WatcherServiceTests extends ESTestCase {
|
||||||
when(watchLockService.tryAcquire("_id", timeout)).thenReturn(lock);
|
when(watchLockService.tryAcquire("_id", timeout)).thenReturn(lock);
|
||||||
Watch watch = mock(Watch.class);
|
Watch watch = mock(Watch.class);
|
||||||
when(watch.ack(now, "_all")).thenReturn(true);
|
when(watch.ack(now, "_all")).thenReturn(true);
|
||||||
WatchStatus status = new WatchStatus(now, ImmutableMap.<String, ActionStatus>of());
|
WatchStatus status = new WatchStatus(now, emptyMap());
|
||||||
when(watch.status()).thenReturn(status);
|
when(watch.status()).thenReturn(status);
|
||||||
when(watchStore.get("_id")).thenReturn(watch);
|
when(watchStore.get("_id")).thenReturn(watch);
|
||||||
|
|
||||||
|
@ -266,7 +272,7 @@ public class WatcherServiceTests extends ESTestCase {
|
||||||
when(watchLockService.tryAcquire("_id", timeout)).thenReturn(lock);
|
when(watchLockService.tryAcquire("_id", timeout)).thenReturn(lock);
|
||||||
|
|
||||||
Watch watch = mock(Watch.class);
|
Watch watch = mock(Watch.class);
|
||||||
WatchStatus status = new WatchStatus(now, ImmutableMap.<String, ActionStatus>of());
|
WatchStatus status = new WatchStatus(now, emptyMap());
|
||||||
when(watch.status()).thenReturn(status);
|
when(watch.status()).thenReturn(status);
|
||||||
when(watch.setState(true, now)).thenReturn(false);
|
when(watch.setState(true, now)).thenReturn(false);
|
||||||
|
|
||||||
|
@ -296,7 +302,7 @@ public class WatcherServiceTests extends ESTestCase {
|
||||||
when(watchLockService.tryAcquire("_id", timeout)).thenReturn(lock);
|
when(watchLockService.tryAcquire("_id", timeout)).thenReturn(lock);
|
||||||
|
|
||||||
Watch watch = mock(Watch.class);
|
Watch watch = mock(Watch.class);
|
||||||
WatchStatus status = new WatchStatus(now, ImmutableMap.<String, ActionStatus>of());
|
WatchStatus status = new WatchStatus(now, emptyMap());
|
||||||
when(watch.status()).thenReturn(status);
|
when(watch.status()).thenReturn(status);
|
||||||
when(watch.setState(true, now)).thenReturn(true);
|
when(watch.setState(true, now)).thenReturn(true);
|
||||||
|
|
||||||
|
@ -325,7 +331,7 @@ public class WatcherServiceTests extends ESTestCase {
|
||||||
|
|
||||||
Watch watch = mock(Watch.class);
|
Watch watch = mock(Watch.class);
|
||||||
when(watch.id()).thenReturn("_id");
|
when(watch.id()).thenReturn("_id");
|
||||||
WatchStatus status = new WatchStatus(now, ImmutableMap.<String, ActionStatus>of());
|
WatchStatus status = new WatchStatus(now, emptyMap());
|
||||||
when(watch.status()).thenReturn(status);
|
when(watch.status()).thenReturn(status);
|
||||||
when(watch.setState(false, now)).thenReturn(true);
|
when(watch.setState(false, now)).thenReturn(true);
|
||||||
|
|
||||||
|
@ -356,7 +362,7 @@ public class WatcherServiceTests extends ESTestCase {
|
||||||
|
|
||||||
Watch watch = mock(Watch.class);
|
Watch watch = mock(Watch.class);
|
||||||
when(watch.id()).thenReturn("_id");
|
when(watch.id()).thenReturn("_id");
|
||||||
WatchStatus status = new WatchStatus(now, ImmutableMap.<String, ActionStatus>of());
|
WatchStatus status = new WatchStatus(now, emptyMap());
|
||||||
when(watch.status()).thenReturn(status);
|
when(watch.status()).thenReturn(status);
|
||||||
when(watch.setState(false, now)).thenReturn(false);
|
when(watch.setState(false, now)).thenReturn(false);
|
||||||
|
|
||||||
|
@ -384,7 +390,7 @@ public class WatcherServiceTests extends ESTestCase {
|
||||||
when(watchLockService.tryAcquire("_id", timeout)).thenReturn(lock);
|
when(watchLockService.tryAcquire("_id", timeout)).thenReturn(lock);
|
||||||
Watch watch = mock(Watch.class);
|
Watch watch = mock(Watch.class);
|
||||||
when(watch.ack(now)).thenReturn(false);
|
when(watch.ack(now)).thenReturn(false);
|
||||||
WatchStatus status = new WatchStatus(now, ImmutableMap.<String, ActionStatus>of());
|
WatchStatus status = new WatchStatus(now, emptyMap());
|
||||||
when(watch.status()).thenReturn(status);
|
when(watch.status()).thenReturn(status);
|
||||||
when(watchStore.get("_id")).thenReturn(watch);
|
when(watchStore.get("_id")).thenReturn(watch);
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.actions.email;
|
package org.elasticsearch.watcher.actions.email;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
import org.apache.lucene.util.LuceneTestCase.AwaitsFix;
|
||||||
import org.elasticsearch.common.io.Streams;
|
import org.elasticsearch.common.io.Streams;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.watcher.actions.email.service.Attachment;
|
import org.elasticsearch.watcher.actions.email.service.Attachment;
|
||||||
|
@ -16,10 +16,9 @@ import java.io.InputStreamReader;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.hamcrest.Matchers.is;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase.AwaitsFix;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -28,7 +27,7 @@ public class DataAttachmentTests extends ESTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreate_Json() throws Exception {
|
public void testCreate_Json() throws Exception {
|
||||||
Map<String, Object> data = ImmutableMap.<String, Object>of("key", "value");
|
Map<String, Object> data = singletonMap("key", "value");
|
||||||
Attachment attachment = DataAttachment.JSON.create(data);
|
Attachment attachment = DataAttachment.JSON.create(data);
|
||||||
InputStream input = attachment.bodyPart().getDataHandler().getInputStream();
|
InputStream input = attachment.bodyPart().getDataHandler().getInputStream();
|
||||||
String content = Streams.copyToString(new InputStreamReader(input, StandardCharsets.UTF_8));
|
String content = Streams.copyToString(new InputStreamReader(input, StandardCharsets.UTF_8));
|
||||||
|
@ -37,7 +36,7 @@ public class DataAttachmentTests extends ESTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreate_Yaml() throws Exception {
|
public void testCreate_Yaml() throws Exception {
|
||||||
Map<String, Object> data = ImmutableMap.<String, Object>of("key", "value");
|
Map<String, Object> data = singletonMap("key", "value");
|
||||||
Attachment attachment = DataAttachment.YAML.create(data);
|
Attachment attachment = DataAttachment.YAML.create(data);
|
||||||
InputStream input = attachment.bodyPart().getDataHandler().getInputStream();
|
InputStream input = attachment.bodyPart().getDataHandler().getInputStream();
|
||||||
String content = Streams.copyToString(new InputStreamReader(input, StandardCharsets.UTF_8));
|
String content = Streams.copyToString(new InputStreamReader(input, StandardCharsets.UTF_8));
|
||||||
|
|
|
@ -5,8 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.actions.index;
|
package org.elasticsearch.watcher.actions.index;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.action.search.SearchResponse;
|
import org.elasticsearch.action.search.SearchResponse;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
@ -32,6 +30,7 @@ import org.junit.Test;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static java.util.Collections.unmodifiableSet;
|
import static java.util.Collections.unmodifiableSet;
|
||||||
import static org.elasticsearch.common.util.set.Sets.newHashSet;
|
import static org.elasticsearch.common.util.set.Sets.newHashSet;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
|
@ -79,7 +78,7 @@ public class IndexActionTests extends ESIntegTestCase {
|
||||||
IndexAction action = new IndexAction("test-index", "test-type", timestampField, null, null);
|
IndexAction action = new IndexAction("test-index", "test-type", timestampField, null, null);
|
||||||
ExecutableIndexAction executable = new ExecutableIndexAction(action, logger, ClientProxy.of(client()), null);
|
ExecutableIndexAction executable = new ExecutableIndexAction(action, logger, ClientProxy.of(client()), null);
|
||||||
DateTime executionTime = DateTime.now(UTC);
|
DateTime executionTime = DateTime.now(UTC);
|
||||||
Payload payload = randomBoolean() ? new Payload.Simple("foo", "bar") : new Payload.Simple("_doc", ImmutableMap.of("foo", "bar"));
|
Payload payload = randomBoolean() ? new Payload.Simple("foo", "bar") : new Payload.Simple("_doc", singletonMap("foo", "bar"));
|
||||||
WatchExecutionContext ctx = WatcherTestUtils.mockExecutionContext("_id", executionTime, payload);
|
WatchExecutionContext ctx = WatcherTestUtils.mockExecutionContext("_id", executionTime, payload);
|
||||||
|
|
||||||
Action.Result result = executable.execute("_id", ctx, ctx.payload());
|
Action.Result result = executable.execute("_id", ctx, ctx.payload());
|
||||||
|
@ -134,9 +133,9 @@ public class IndexActionTests extends ESIntegTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
Object list = randomFrom(
|
Object list = randomFrom(
|
||||||
new Map[] { ImmutableMap.of("foo", "bar"), ImmutableMap.of("foo", "bar1") },
|
new Map[] { singletonMap("foo", "bar"), singletonMap("foo", "bar1") },
|
||||||
Arrays.asList(ImmutableMap.of("foo", "bar"), ImmutableMap.of("foo", "bar1")),
|
Arrays.asList(singletonMap("foo", "bar"), singletonMap("foo", "bar1")),
|
||||||
unmodifiableSet(newHashSet(ImmutableMap.of("foo", "bar"), ImmutableMap.of("foo", "bar1")))
|
unmodifiableSet(newHashSet(singletonMap("foo", "bar"), singletonMap("foo", "bar1")))
|
||||||
);
|
);
|
||||||
|
|
||||||
IndexAction action = new IndexAction("test-index", "test-type", timestampField, null, null);
|
IndexAction action = new IndexAction("test-index", "test-type", timestampField, null, null);
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.actions.logging;
|
package org.elasticsearch.watcher.actions.logging;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.logging.ESLogger;
|
import org.elasticsearch.common.logging.ESLogger;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
@ -25,9 +24,11 @@ import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Collections;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.watcher.actions.ActionBuilders.loggingAction;
|
import static org.elasticsearch.watcher.actions.ActionBuilders.loggingAction;
|
||||||
import static org.hamcrest.CoreMatchers.instanceOf;
|
import static org.hamcrest.CoreMatchers.instanceOf;
|
||||||
|
@ -35,7 +36,10 @@ import static org.hamcrest.CoreMatchers.notNullValue;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.core.Is.is;
|
import static org.hamcrest.core.Is.is;
|
||||||
import static org.joda.time.DateTimeZone.UTC;
|
import static org.joda.time.DateTimeZone.UTC;
|
||||||
import static org.mockito.Mockito.*;
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.times;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
|
@ -60,20 +64,18 @@ public class LoggingActionTests extends ESTestCase {
|
||||||
.time("_watch_id", now)
|
.time("_watch_id", now)
|
||||||
.buildMock();
|
.buildMock();
|
||||||
|
|
||||||
final Map<String, Object> expectedModel = ImmutableMap.<String, Object>builder()
|
Map<String, Object> triggerModel = new HashMap<>();
|
||||||
.put("ctx", ImmutableMap.builder()
|
triggerModel.put("scheduled_time", now);
|
||||||
.put("id", ctx.id().value())
|
triggerModel.put("triggered_time", now);
|
||||||
.put("watch_id", "_watch_id")
|
Map<String, Object> ctxModel = new HashMap<>();
|
||||||
.put("execution_time", now)
|
ctxModel.put("id", ctx.id().value());
|
||||||
.put("payload", ImmutableMap.of())
|
ctxModel.put("watch_id", "_watch_id");
|
||||||
.put("metadata", ImmutableMap.of())
|
ctxModel.put("execution_time", now);
|
||||||
.put("trigger", ImmutableMap.builder()
|
ctxModel.put("payload", emptyMap());
|
||||||
.put("scheduled_time", now)
|
ctxModel.put("metadata", emptyMap());
|
||||||
.put("triggered_time", now)
|
ctxModel.put("vars", emptyMap());
|
||||||
.build())
|
ctxModel.put("trigger", triggerModel);
|
||||||
.put("vars", Collections.emptyMap())
|
Map<String, Object> expectedModel = singletonMap("ctx", ctxModel);
|
||||||
.build())
|
|
||||||
.build();
|
|
||||||
|
|
||||||
String text = randomAsciiOfLength(10);
|
String text = randomAsciiOfLength(10);
|
||||||
TextTemplate template = TextTemplate.inline(text).build();
|
TextTemplate template = TextTemplate.inline(text).build();
|
||||||
|
|
|
@ -5,8 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.actions.webhook;
|
package org.elasticsearch.watcher.actions.webhook;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase.AwaitsFix;
|
import org.apache.lucene.util.LuceneTestCase.AwaitsFix;
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
@ -18,11 +16,18 @@ import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.threadpool.ThreadPool;
|
import org.elasticsearch.threadpool.ThreadPool;
|
||||||
import org.elasticsearch.watcher.actions.Action;
|
import org.elasticsearch.watcher.actions.Action;
|
||||||
import org.elasticsearch.watcher.actions.Action.Result.Status;
|
import org.elasticsearch.watcher.actions.Action.Result.Status;
|
||||||
import org.elasticsearch.watcher.actions.email.service.*;
|
import org.elasticsearch.watcher.actions.email.service.Attachment;
|
||||||
|
import org.elasticsearch.watcher.actions.email.service.Authentication;
|
||||||
|
import org.elasticsearch.watcher.actions.email.service.Email;
|
||||||
|
import org.elasticsearch.watcher.actions.email.service.EmailService;
|
||||||
|
import org.elasticsearch.watcher.actions.email.service.Profile;
|
||||||
import org.elasticsearch.watcher.execution.TriggeredExecutionContext;
|
import org.elasticsearch.watcher.execution.TriggeredExecutionContext;
|
||||||
import org.elasticsearch.watcher.execution.WatchExecutionContext;
|
import org.elasticsearch.watcher.execution.WatchExecutionContext;
|
||||||
import org.elasticsearch.watcher.support.http.*;
|
import org.elasticsearch.watcher.support.http.HttpClient;
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthFactory;
|
import org.elasticsearch.watcher.support.http.HttpMethod;
|
||||||
|
import org.elasticsearch.watcher.support.http.HttpRequest;
|
||||||
|
import org.elasticsearch.watcher.support.http.HttpRequestTemplate;
|
||||||
|
import org.elasticsearch.watcher.support.http.HttpResponse;
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
||||||
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
||||||
import org.elasticsearch.watcher.support.init.proxy.ClientProxy;
|
import org.elasticsearch.watcher.support.init.proxy.ClientProxy;
|
||||||
|
@ -41,21 +46,27 @@ import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import javax.mail.internet.AddressException;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import javax.mail.internet.AddressException;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.hamcrest.CoreMatchers.instanceOf;
|
import static org.hamcrest.CoreMatchers.instanceOf;
|
||||||
import static org.hamcrest.CoreMatchers.notNullValue;
|
import static org.hamcrest.CoreMatchers.notNullValue;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.greaterThanOrEqualTo;
|
||||||
|
import static org.hamcrest.Matchers.lessThanOrEqualTo;
|
||||||
import static org.hamcrest.core.Is.is;
|
import static org.hamcrest.core.Is.is;
|
||||||
import static org.joda.time.DateTimeZone.UTC;
|
import static org.joda.time.DateTimeZone.UTC;
|
||||||
import static org.mockito.Matchers.any;
|
import static org.mockito.Matchers.any;
|
||||||
import static org.mockito.Mockito.*;
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.never;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -86,7 +97,7 @@ public class WebhookActionTests extends ESTestCase {
|
||||||
SecretService secretService = mock(SecretService.class);
|
SecretService secretService = mock(SecretService.class);
|
||||||
testBody = TextTemplate.inline(TEST_BODY_STRING).build();
|
testBody = TextTemplate.inline(TEST_BODY_STRING).build();
|
||||||
testPath = TextTemplate.inline(TEST_PATH_STRING).build();
|
testPath = TextTemplate.inline(TEST_PATH_STRING).build();
|
||||||
authRegistry = new HttpAuthRegistry(ImmutableMap.of("basic", (HttpAuthFactory) new BasicAuthFactory(secretService)));
|
authRegistry = new HttpAuthRegistry(singletonMap("basic", new BasicAuthFactory(secretService)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.condition.compare;
|
package org.elasticsearch.watcher.condition.compare;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
|
@ -23,6 +22,7 @@ import org.junit.Test;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.watcher.test.WatcherTestUtils.mockExecutionContext;
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.mockExecutionContext;
|
||||||
import static org.hamcrest.Matchers.is;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
@ -46,8 +46,8 @@ public class CompareConditionTests extends ESTestCase {
|
||||||
assertThat(Op.EQ.eval("a", "aa"), is(false));
|
assertThat(Op.EQ.eval("a", "aa"), is(false));
|
||||||
assertThat(Op.EQ.eval("a", "a"), is(true));
|
assertThat(Op.EQ.eval("a", "a"), is(true));
|
||||||
assertThat(Op.EQ.eval("aa", "ab"), is(false));
|
assertThat(Op.EQ.eval("aa", "ab"), is(false));
|
||||||
assertThat(Op.EQ.eval(ImmutableMap.of("k", "v"), ImmutableMap.of("k", "v")), is(true));
|
assertThat(Op.EQ.eval(singletonMap("k", "v"), singletonMap("k", "v")), is(true));
|
||||||
assertThat(Op.EQ.eval(ImmutableMap.of("k", "v"), ImmutableMap.of("k1", "v1")), is(false));
|
assertThat(Op.EQ.eval(singletonMap("k", "v"), singletonMap("k1", "v1")), is(false));
|
||||||
assertThat(Op.EQ.eval(Arrays.asList("k", "v"), Arrays.asList("k", "v")), is(true));
|
assertThat(Op.EQ.eval(Arrays.asList("k", "v"), Arrays.asList("k", "v")), is(true));
|
||||||
assertThat(Op.EQ.eval(Arrays.asList("k", "v"), Arrays.asList("k1", "v1")), is(false));
|
assertThat(Op.EQ.eval(Arrays.asList("k", "v"), Arrays.asList("k1", "v1")), is(false));
|
||||||
}
|
}
|
||||||
|
@ -66,8 +66,8 @@ public class CompareConditionTests extends ESTestCase {
|
||||||
assertThat(Op.NOT_EQ.eval("a", "aa"), is(true));
|
assertThat(Op.NOT_EQ.eval("a", "aa"), is(true));
|
||||||
assertThat(Op.NOT_EQ.eval("a", "a"), is(false));
|
assertThat(Op.NOT_EQ.eval("a", "a"), is(false));
|
||||||
assertThat(Op.NOT_EQ.eval("aa", "ab"), is(true));
|
assertThat(Op.NOT_EQ.eval("aa", "ab"), is(true));
|
||||||
assertThat(Op.NOT_EQ.eval(ImmutableMap.of("k", "v"), ImmutableMap.of("k", "v")), is(false));
|
assertThat(Op.NOT_EQ.eval(singletonMap("k", "v"), singletonMap("k", "v")), is(false));
|
||||||
assertThat(Op.NOT_EQ.eval(ImmutableMap.of("k", "v"), ImmutableMap.of("k1", "v1")), is(true));
|
assertThat(Op.NOT_EQ.eval(singletonMap("k", "v"), singletonMap("k1", "v1")), is(true));
|
||||||
assertThat(Op.NOT_EQ.eval(Arrays.asList("k", "v"), Arrays.asList("k", "v")), is(false));
|
assertThat(Op.NOT_EQ.eval(Arrays.asList("k", "v"), Arrays.asList("k", "v")), is(false));
|
||||||
assertThat(Op.NOT_EQ.eval(Arrays.asList("k", "v"), Arrays.asList("k1", "v1")), is(true));
|
assertThat(Op.NOT_EQ.eval(Arrays.asList("k", "v"), Arrays.asList("k1", "v1")), is(true));
|
||||||
}
|
}
|
||||||
|
@ -226,7 +226,7 @@ public class CompareConditionTests extends ESTestCase {
|
||||||
|
|
||||||
@Test(expected = ElasticsearchParseException.class)
|
@Test(expected = ElasticsearchParseException.class)
|
||||||
public void testParse_InValid_WrongValueForOp() throws Exception {
|
public void testParse_InValid_WrongValueForOp() throws Exception {
|
||||||
Object value = randomFrom(Arrays.asList("1", "2"), ImmutableMap.of("key", "value"));
|
Object value = randomFrom(Arrays.asList("1", "2"), singletonMap("key", "value"));
|
||||||
String op = randomFrom("lt", "lte", "gt", "gte");
|
String op = randomFrom("lt", "lte", "gt", "gte");
|
||||||
CompareConditionFactory factory = new CompareConditionFactory(Settings.EMPTY, SystemClock.INSTANCE);
|
CompareConditionFactory factory = new CompareConditionFactory(Settings.EMPTY, SystemClock.INSTANCE);
|
||||||
XContentBuilder builder = jsonBuilder();
|
XContentBuilder builder = jsonBuilder();
|
||||||
|
|
|
@ -6,8 +6,6 @@
|
||||||
package org.elasticsearch.watcher.condition.script;
|
package org.elasticsearch.watcher.condition.script;
|
||||||
|
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase.AwaitsFix;
|
import org.apache.lucene.util.LuceneTestCase.AwaitsFix;
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.action.search.SearchResponse;
|
import org.elasticsearch.action.search.SearchResponse;
|
||||||
|
@ -35,11 +33,14 @@ import org.junit.Test;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.watcher.support.Exceptions.illegalArgument;
|
import static org.elasticsearch.watcher.support.Exceptions.illegalArgument;
|
||||||
import static org.elasticsearch.watcher.test.WatcherTestUtils.getScriptServiceProxy;
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.getScriptServiceProxy;
|
||||||
import static org.elasticsearch.watcher.test.WatcherTestUtils.mockExecutionContext;
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.mockExecutionContext;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
|
@ -71,7 +72,7 @@ public class ScriptConditionTests extends ESTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testExecute_MergedParams() throws Exception {
|
public void testExecute_MergedParams() throws Exception {
|
||||||
ScriptServiceProxy scriptService = getScriptServiceProxy(tp);
|
ScriptServiceProxy scriptService = getScriptServiceProxy(tp);
|
||||||
Script script = Script.inline("ctx.payload.hits.total > threshold").lang(ScriptService.DEFAULT_LANG).params(ImmutableMap.<String, Object>of("threshold", 1)).build();
|
Script script = Script.inline("ctx.payload.hits.total > threshold").lang(ScriptService.DEFAULT_LANG).params(singletonMap("threshold", 1)).build();
|
||||||
ExecutableScriptCondition executable = new ExecutableScriptCondition(new ScriptCondition(script), logger, scriptService);
|
ExecutableScriptCondition executable = new ExecutableScriptCondition(new ScriptCondition(script), logger, scriptService);
|
||||||
SearchResponse response = new SearchResponse(InternalSearchResponse.empty(), "", 3, 3, 500l, new ShardSearchFailure[0]);
|
SearchResponse response = new SearchResponse(InternalSearchResponse.empty(), "", 3, 3, 500l, new ShardSearchFailure[0]);
|
||||||
WatchExecutionContext ctx = mockExecutionContext("_name", new Payload.XContent(response));
|
WatchExecutionContext ctx = mockExecutionContext("_name", new Payload.XContent(response));
|
||||||
|
|
|
@ -5,11 +5,14 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.execution;
|
package org.elasticsearch.watcher.execution;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.cluster.ClusterState;
|
import org.elasticsearch.cluster.ClusterState;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.watcher.actions.*;
|
import org.elasticsearch.watcher.actions.Action;
|
||||||
|
import org.elasticsearch.watcher.actions.ActionStatus;
|
||||||
|
import org.elasticsearch.watcher.actions.ActionWrapper;
|
||||||
|
import org.elasticsearch.watcher.actions.ExecutableAction;
|
||||||
|
import org.elasticsearch.watcher.actions.ExecutableActions;
|
||||||
import org.elasticsearch.watcher.actions.throttler.ActionThrottler;
|
import org.elasticsearch.watcher.actions.throttler.ActionThrottler;
|
||||||
import org.elasticsearch.watcher.actions.throttler.Throttler;
|
import org.elasticsearch.watcher.actions.throttler.Throttler;
|
||||||
import org.elasticsearch.watcher.condition.Condition;
|
import org.elasticsearch.watcher.condition.Condition;
|
||||||
|
@ -26,7 +29,11 @@ import org.elasticsearch.watcher.support.validation.WatcherSettingsValidation;
|
||||||
import org.elasticsearch.watcher.transform.ExecutableTransform;
|
import org.elasticsearch.watcher.transform.ExecutableTransform;
|
||||||
import org.elasticsearch.watcher.transform.Transform;
|
import org.elasticsearch.watcher.transform.Transform;
|
||||||
import org.elasticsearch.watcher.trigger.schedule.ScheduleTriggerEvent;
|
import org.elasticsearch.watcher.trigger.schedule.ScheduleTriggerEvent;
|
||||||
import org.elasticsearch.watcher.watch.*;
|
import org.elasticsearch.watcher.watch.Payload;
|
||||||
|
import org.elasticsearch.watcher.watch.Watch;
|
||||||
|
import org.elasticsearch.watcher.watch.WatchLockService;
|
||||||
|
import org.elasticsearch.watcher.watch.WatchStatus;
|
||||||
|
import org.elasticsearch.watcher.watch.WatchStore;
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
import org.joda.time.DateTimeZone;
|
import org.joda.time.DateTimeZone;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
|
@ -36,10 +43,19 @@ import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.concurrent.ArrayBlockingQueue;
|
import java.util.concurrent.ArrayBlockingQueue;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.instanceOf;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
|
import static org.hamcrest.Matchers.nullValue;
|
||||||
|
import static org.hamcrest.Matchers.sameInstance;
|
||||||
import static org.mockito.Matchers.any;
|
import static org.mockito.Matchers.any;
|
||||||
import static org.mockito.Mockito.*;
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.never;
|
||||||
|
import static org.mockito.Mockito.times;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
|
@ -127,7 +143,7 @@ public class ExecutionServiceTests extends ESTestCase {
|
||||||
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
||||||
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
||||||
|
|
||||||
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), ImmutableMap.of("_action", new ActionStatus(clock.nowUTC())));
|
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), singletonMap("_action", new ActionStatus(clock.nowUTC())));
|
||||||
|
|
||||||
when(watch.input()).thenReturn(input);
|
when(watch.input()).thenReturn(input);
|
||||||
when(watch.condition()).thenReturn(condition);
|
when(watch.condition()).thenReturn(condition);
|
||||||
|
@ -201,7 +217,7 @@ public class ExecutionServiceTests extends ESTestCase {
|
||||||
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
||||||
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
||||||
|
|
||||||
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), ImmutableMap.of("_action", new ActionStatus(clock.nowUTC())));
|
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), singletonMap("_action", new ActionStatus(clock.nowUTC())));
|
||||||
|
|
||||||
when(watch.input()).thenReturn(input);
|
when(watch.input()).thenReturn(input);
|
||||||
when(watch.condition()).thenReturn(condition);
|
when(watch.condition()).thenReturn(condition);
|
||||||
|
@ -270,7 +286,7 @@ public class ExecutionServiceTests extends ESTestCase {
|
||||||
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
||||||
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
||||||
|
|
||||||
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), ImmutableMap.of("_action", new ActionStatus(clock.nowUTC())));
|
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), singletonMap("_action", new ActionStatus(clock.nowUTC())));
|
||||||
|
|
||||||
when(watch.input()).thenReturn(input);
|
when(watch.input()).thenReturn(input);
|
||||||
when(watch.condition()).thenReturn(condition);
|
when(watch.condition()).thenReturn(condition);
|
||||||
|
@ -338,7 +354,7 @@ public class ExecutionServiceTests extends ESTestCase {
|
||||||
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
||||||
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
||||||
|
|
||||||
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), ImmutableMap.of("_action", new ActionStatus(clock.nowUTC())));
|
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), singletonMap("_action", new ActionStatus(clock.nowUTC())));
|
||||||
|
|
||||||
when(watch.input()).thenReturn(input);
|
when(watch.input()).thenReturn(input);
|
||||||
when(watch.condition()).thenReturn(condition);
|
when(watch.condition()).thenReturn(condition);
|
||||||
|
@ -408,7 +424,7 @@ public class ExecutionServiceTests extends ESTestCase {
|
||||||
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
||||||
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
||||||
|
|
||||||
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), ImmutableMap.of("_action", new ActionStatus(clock.nowUTC())));
|
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), singletonMap("_action", new ActionStatus(clock.nowUTC())));
|
||||||
|
|
||||||
when(watch.input()).thenReturn(input);
|
when(watch.input()).thenReturn(input);
|
||||||
when(watch.condition()).thenReturn(condition);
|
when(watch.condition()).thenReturn(condition);
|
||||||
|
@ -473,7 +489,7 @@ public class ExecutionServiceTests extends ESTestCase {
|
||||||
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
||||||
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
||||||
|
|
||||||
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), ImmutableMap.of("_action", new ActionStatus(now)));
|
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), singletonMap("_action", new ActionStatus(now)));
|
||||||
|
|
||||||
when(watch.input()).thenReturn(input);
|
when(watch.input()).thenReturn(input);
|
||||||
when(watch.condition()).thenReturn(condition);
|
when(watch.condition()).thenReturn(condition);
|
||||||
|
@ -519,7 +535,7 @@ public class ExecutionServiceTests extends ESTestCase {
|
||||||
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, transform, action);
|
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, transform, action);
|
||||||
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
||||||
|
|
||||||
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), ImmutableMap.of("_action", new ActionStatus(now)));
|
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), singletonMap("_action", new ActionStatus(now)));
|
||||||
|
|
||||||
when(watch.input()).thenReturn(input);
|
when(watch.input()).thenReturn(input);
|
||||||
when(watch.condition()).thenReturn(condition);
|
when(watch.condition()).thenReturn(condition);
|
||||||
|
@ -565,7 +581,7 @@ public class ExecutionServiceTests extends ESTestCase {
|
||||||
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
ActionWrapper actionWrapper = new ActionWrapper("_action", throttler, actionTransform, action);
|
||||||
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
ExecutableActions actions = new ExecutableActions(Arrays.asList(actionWrapper));
|
||||||
|
|
||||||
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), ImmutableMap.of("_action", new ActionStatus(now)));
|
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), singletonMap("_action", new ActionStatus(now)));
|
||||||
|
|
||||||
when(watch.input()).thenReturn(input);
|
when(watch.input()).thenReturn(input);
|
||||||
when(watch.condition()).thenReturn(condition);
|
when(watch.condition()).thenReturn(condition);
|
||||||
|
|
|
@ -5,13 +5,13 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.input;
|
package org.elasticsearch.watcher.input;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.common.xcontent.json.JsonXContent;
|
import org.elasticsearch.common.xcontent.json.JsonXContent;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -21,7 +21,7 @@ public class InputRegistryTests extends ESTestCase {
|
||||||
|
|
||||||
@Test(expected = ElasticsearchParseException.class)
|
@Test(expected = ElasticsearchParseException.class)
|
||||||
public void testParse_EmptyInput() throws Exception {
|
public void testParse_EmptyInput() throws Exception {
|
||||||
InputRegistry registry = new InputRegistry(ImmutableMap.<String, InputFactory>of());
|
InputRegistry registry = new InputRegistry(emptyMap());
|
||||||
XContentParser parser = JsonXContent.jsonXContent.createParser(
|
XContentParser parser = JsonXContent.jsonXContent.createParser(
|
||||||
jsonBuilder().startObject().endObject().bytes());
|
jsonBuilder().startObject().endObject().bytes());
|
||||||
parser.nextToken();
|
parser.nextToken();
|
||||||
|
@ -31,7 +31,7 @@ public class InputRegistryTests extends ESTestCase {
|
||||||
|
|
||||||
@Test(expected = ElasticsearchParseException.class)
|
@Test(expected = ElasticsearchParseException.class)
|
||||||
public void testParse_ArrayInput() throws Exception {
|
public void testParse_ArrayInput() throws Exception {
|
||||||
InputRegistry registry = new InputRegistry(ImmutableMap.<String, InputFactory>of());
|
InputRegistry registry = new InputRegistry(emptyMap());
|
||||||
XContentParser parser = JsonXContent.jsonXContent.createParser(
|
XContentParser parser = JsonXContent.jsonXContent.createParser(
|
||||||
jsonBuilder().startArray().endArray().bytes());
|
jsonBuilder().startArray().endArray().bytes());
|
||||||
parser.nextToken();
|
parser.nextToken();
|
||||||
|
|
|
@ -6,10 +6,7 @@
|
||||||
package org.elasticsearch.watcher.input.http;
|
package org.elasticsearch.watcher.input.http;
|
||||||
|
|
||||||
import org.elasticsearch.common.bytes.BytesReference;
|
import org.elasticsearch.common.bytes.BytesReference;
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.common.collect.MapBuilder;
|
import org.elasticsearch.common.collect.MapBuilder;
|
||||||
import org.jboss.netty.handler.codec.http.HttpHeaders;
|
|
||||||
import org.joda.time.DateTime;
|
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
|
@ -17,7 +14,6 @@ import org.elasticsearch.common.xcontent.XContentHelper;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.common.xcontent.XContentType;
|
import org.elasticsearch.common.xcontent.XContentType;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.watcher.actions.ActionStatus;
|
|
||||||
import org.elasticsearch.watcher.actions.ActionWrapper;
|
import org.elasticsearch.watcher.actions.ActionWrapper;
|
||||||
import org.elasticsearch.watcher.actions.ExecutableActions;
|
import org.elasticsearch.watcher.actions.ExecutableActions;
|
||||||
import org.elasticsearch.watcher.condition.always.ExecutableAlwaysCondition;
|
import org.elasticsearch.watcher.condition.always.ExecutableAlwaysCondition;
|
||||||
|
@ -26,9 +22,14 @@ import org.elasticsearch.watcher.execution.WatchExecutionContext;
|
||||||
import org.elasticsearch.watcher.input.InputBuilders;
|
import org.elasticsearch.watcher.input.InputBuilders;
|
||||||
import org.elasticsearch.watcher.input.simple.ExecutableSimpleInput;
|
import org.elasticsearch.watcher.input.simple.ExecutableSimpleInput;
|
||||||
import org.elasticsearch.watcher.input.simple.SimpleInput;
|
import org.elasticsearch.watcher.input.simple.SimpleInput;
|
||||||
import org.elasticsearch.watcher.support.http.*;
|
import org.elasticsearch.watcher.support.http.HttpClient;
|
||||||
|
import org.elasticsearch.watcher.support.http.HttpContentType;
|
||||||
|
import org.elasticsearch.watcher.support.http.HttpMethod;
|
||||||
|
import org.elasticsearch.watcher.support.http.HttpRequest;
|
||||||
|
import org.elasticsearch.watcher.support.http.HttpRequestTemplate;
|
||||||
|
import org.elasticsearch.watcher.support.http.HttpResponse;
|
||||||
|
import org.elasticsearch.watcher.support.http.Scheme;
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuth;
|
import org.elasticsearch.watcher.support.http.auth.HttpAuth;
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthFactory;
|
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
||||||
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuth;
|
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuth;
|
||||||
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
||||||
|
@ -41,6 +42,8 @@ import org.elasticsearch.watcher.trigger.schedule.ScheduleTriggerEvent;
|
||||||
import org.elasticsearch.watcher.watch.Payload;
|
import org.elasticsearch.watcher.watch.Payload;
|
||||||
import org.elasticsearch.watcher.watch.Watch;
|
import org.elasticsearch.watcher.watch.Watch;
|
||||||
import org.elasticsearch.watcher.watch.WatchStatus;
|
import org.elasticsearch.watcher.watch.WatchStatus;
|
||||||
|
import org.jboss.netty.handler.codec.http.HttpHeaders;
|
||||||
|
import org.joda.time.DateTime;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -48,9 +51,14 @@ import java.nio.charset.StandardCharsets;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import static org.joda.time.DateTimeZone.UTC;
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.hasEntry;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.Matchers.nullValue;
|
||||||
|
import static org.joda.time.DateTimeZone.UTC;
|
||||||
import static org.mockito.Matchers.any;
|
import static org.mockito.Matchers.any;
|
||||||
import static org.mockito.Matchers.eq;
|
import static org.mockito.Matchers.eq;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
|
@ -70,7 +78,7 @@ public class HttpInputTests extends ESTestCase {
|
||||||
httpClient = mock(HttpClient.class);
|
httpClient = mock(HttpClient.class);
|
||||||
templateEngine = mock(TextTemplateEngine.class);
|
templateEngine = mock(TextTemplateEngine.class);
|
||||||
secretService = mock(SecretService.class);
|
secretService = mock(SecretService.class);
|
||||||
HttpAuthRegistry registry = new HttpAuthRegistry(ImmutableMap.<String, HttpAuthFactory>of("basic", new BasicAuthFactory(secretService)));
|
HttpAuthRegistry registry = new HttpAuthRegistry(singletonMap("basic", new BasicAuthFactory(secretService)));
|
||||||
httpParser = new HttpInputFactory(Settings.EMPTY, httpClient, templateEngine, new HttpRequest.Parser(registry), new HttpRequestTemplate.Parser(registry));
|
httpParser = new HttpInputFactory(Settings.EMPTY, httpClient, templateEngine, new HttpRequest.Parser(registry), new HttpRequestTemplate.Parser(registry));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,19 +102,19 @@ public class HttpInputTests extends ESTestCase {
|
||||||
httpInput = InputBuilders.httpInput(request.build()).expectedResponseXContentType(HttpContentType.YAML).build();
|
httpInput = InputBuilders.httpInput(request.build()).expectedResponseXContentType(HttpContentType.YAML).build();
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
response = new HttpResponse(123, "{\"key\" : \"value\"}".getBytes(StandardCharsets.UTF_8), ImmutableMap.of(HttpHeaders.Names.CONTENT_TYPE, new String[] { XContentType.JSON.restContentType() }));
|
response = new HttpResponse(123, "{\"key\" : \"value\"}".getBytes(StandardCharsets.UTF_8), singletonMap(HttpHeaders.Names.CONTENT_TYPE, new String[] { XContentType.JSON.restContentType() }));
|
||||||
httpInput = InputBuilders.httpInput(request.build()).build();
|
httpInput = InputBuilders.httpInput(request.build()).build();
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
response = new HttpResponse(123, "key: value".getBytes(StandardCharsets.UTF_8), ImmutableMap.of(HttpHeaders.Names.CONTENT_TYPE, new String[] { XContentType.YAML.restContentType() }));
|
response = new HttpResponse(123, "key: value".getBytes(StandardCharsets.UTF_8), singletonMap(HttpHeaders.Names.CONTENT_TYPE, new String[] { XContentType.YAML.restContentType() }));
|
||||||
httpInput = InputBuilders.httpInput(request.build()).build();
|
httpInput = InputBuilders.httpInput(request.build()).build();
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
response = new HttpResponse(123, "---\nkey: value".getBytes(StandardCharsets.UTF_8), ImmutableMap.of(HttpHeaders.Names.CONTENT_TYPE, new String[] { "unrecognized_content_type" }));
|
response = new HttpResponse(123, "---\nkey: value".getBytes(StandardCharsets.UTF_8), singletonMap(HttpHeaders.Names.CONTENT_TYPE, new String[] { "unrecognized_content_type" }));
|
||||||
httpInput = InputBuilders.httpInput(request.build()).expectedResponseXContentType(HttpContentType.YAML).build();
|
httpInput = InputBuilders.httpInput(request.build()).expectedResponseXContentType(HttpContentType.YAML).build();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
response = new HttpResponse(123, "{\"key\" : \"value\"}".getBytes(StandardCharsets.UTF_8), ImmutableMap.of(HttpHeaders.Names.CONTENT_TYPE, new String[] { "unrecognized_content_type" }));
|
response = new HttpResponse(123, "{\"key\" : \"value\"}".getBytes(StandardCharsets.UTF_8), singletonMap(HttpHeaders.Names.CONTENT_TYPE, new String[] { "unrecognized_content_type" }));
|
||||||
httpInput = InputBuilders.httpInput(request.build()).build();
|
httpInput = InputBuilders.httpInput(request.build()).build();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -125,7 +133,7 @@ public class HttpInputTests extends ESTestCase {
|
||||||
null,
|
null,
|
||||||
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
||||||
null,
|
null,
|
||||||
new WatchStatus(new DateTime(0, UTC), ImmutableMap.<String, ActionStatus>of()));
|
new WatchStatus(new DateTime(0, UTC), emptyMap()));
|
||||||
WatchExecutionContext ctx = new TriggeredExecutionContext(watch,
|
WatchExecutionContext ctx = new TriggeredExecutionContext(watch,
|
||||||
new DateTime(0, UTC),
|
new DateTime(0, UTC),
|
||||||
new ScheduleTriggerEvent(watch.id(), new DateTime(0, UTC), new DateTime(0, UTC)),
|
new ScheduleTriggerEvent(watch.id(), new DateTime(0, UTC), new DateTime(0, UTC)),
|
||||||
|
@ -156,7 +164,7 @@ public class HttpInputTests extends ESTestCase {
|
||||||
null,
|
null,
|
||||||
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
||||||
null,
|
null,
|
||||||
new WatchStatus(new DateTime(0, UTC), ImmutableMap.<String, ActionStatus>of()));
|
new WatchStatus(new DateTime(0, UTC), emptyMap()));
|
||||||
WatchExecutionContext ctx = new TriggeredExecutionContext(watch,
|
WatchExecutionContext ctx = new TriggeredExecutionContext(watch,
|
||||||
new DateTime(0, UTC),
|
new DateTime(0, UTC),
|
||||||
new ScheduleTriggerEvent(watch.id(), new DateTime(0, UTC), new DateTime(0, UTC)),
|
new ScheduleTriggerEvent(watch.id(), new DateTime(0, UTC), new DateTime(0, UTC)),
|
||||||
|
|
|
@ -5,8 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.input.search;
|
package org.elasticsearch.watcher.input.search;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptRequest;
|
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptRequest;
|
||||||
import org.elasticsearch.action.search.SearchRequest;
|
import org.elasticsearch.action.search.SearchRequest;
|
||||||
import org.elasticsearch.action.search.SearchType;
|
import org.elasticsearch.action.search.SearchType;
|
||||||
|
@ -21,7 +19,6 @@ import org.elasticsearch.common.xcontent.support.XContentMapValues;
|
||||||
import org.elasticsearch.search.builder.SearchSourceBuilder;
|
import org.elasticsearch.search.builder.SearchSourceBuilder;
|
||||||
import org.elasticsearch.test.ESIntegTestCase;
|
import org.elasticsearch.test.ESIntegTestCase;
|
||||||
import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
||||||
import org.elasticsearch.watcher.actions.ActionStatus;
|
|
||||||
import org.elasticsearch.watcher.actions.ActionWrapper;
|
import org.elasticsearch.watcher.actions.ActionWrapper;
|
||||||
import org.elasticsearch.watcher.actions.ExecutableActions;
|
import org.elasticsearch.watcher.actions.ExecutableActions;
|
||||||
import org.elasticsearch.watcher.condition.always.ExecutableAlwaysCondition;
|
import org.elasticsearch.watcher.condition.always.ExecutableAlwaysCondition;
|
||||||
|
@ -49,15 +46,20 @@ import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
import static org.elasticsearch.common.settings.Settings.settingsBuilder;
|
import static org.elasticsearch.common.settings.Settings.settingsBuilder;
|
||||||
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.*;
|
import static org.elasticsearch.index.query.QueryBuilders.boolQuery;
|
||||||
|
import static org.elasticsearch.index.query.QueryBuilders.matchQuery;
|
||||||
|
import static org.elasticsearch.index.query.QueryBuilders.rangeQuery;
|
||||||
import static org.elasticsearch.search.builder.SearchSourceBuilder.searchSource;
|
import static org.elasticsearch.search.builder.SearchSourceBuilder.searchSource;
|
||||||
import static org.elasticsearch.test.ESIntegTestCase.Scope.SUITE;
|
import static org.elasticsearch.test.ESIntegTestCase.Scope.SUITE;
|
||||||
import static org.elasticsearch.watcher.test.WatcherTestUtils.areJsonEquivalent;
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.areJsonEquivalent;
|
||||||
import static org.elasticsearch.watcher.test.WatcherTestUtils.getRandomSupportedSearchType;
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.getRandomSupportedSearchType;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.Matchers.startsWith;
|
||||||
import static org.joda.time.DateTimeZone.UTC;
|
import static org.joda.time.DateTimeZone.UTC;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -121,7 +123,7 @@ public class SearchInputTests extends ESIntegTestCase {
|
||||||
null,
|
null,
|
||||||
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
||||||
null,
|
null,
|
||||||
new WatchStatus(new DateTime(0, UTC), ImmutableMap.<String, ActionStatus>of())),
|
new WatchStatus(new DateTime(0, UTC), emptyMap())),
|
||||||
new DateTime(0, UTC),
|
new DateTime(0, UTC),
|
||||||
new ScheduleTriggerEvent("test-watch", new DateTime(0, UTC), new DateTime(0, UTC)),
|
new ScheduleTriggerEvent("test-watch", new DateTime(0, UTC), new DateTime(0, UTC)),
|
||||||
timeValueSeconds(5));
|
timeValueSeconds(5));
|
||||||
|
@ -228,7 +230,7 @@ public class SearchInputTests extends ESIntegTestCase {
|
||||||
null,
|
null,
|
||||||
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
||||||
null,
|
null,
|
||||||
new WatchStatus(new DateTime(0, UTC), ImmutableMap.<String, ActionStatus>of())),
|
new WatchStatus(new DateTime(0, UTC), emptyMap())),
|
||||||
new DateTime(0, UTC),
|
new DateTime(0, UTC),
|
||||||
new ScheduleTriggerEvent("test-watch", new DateTime(0, UTC), new DateTime(0, UTC)),
|
new ScheduleTriggerEvent("test-watch", new DateTime(0, UTC), new DateTime(0, UTC)),
|
||||||
timeValueSeconds(5));
|
timeValueSeconds(5));
|
||||||
|
@ -271,7 +273,7 @@ public class SearchInputTests extends ESIntegTestCase {
|
||||||
null,
|
null,
|
||||||
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
||||||
null,
|
null,
|
||||||
new WatchStatus(new DateTime(50000, UTC), ImmutableMap.<String, ActionStatus>of())),
|
new WatchStatus(new DateTime(50000, UTC), emptyMap())),
|
||||||
new DateTime(60000, UTC),
|
new DateTime(60000, UTC),
|
||||||
new ScheduleTriggerEvent("test-watch", new DateTime(60000, UTC), new DateTime(60000, UTC)),
|
new ScheduleTriggerEvent("test-watch", new DateTime(60000, UTC), new DateTime(60000, UTC)),
|
||||||
timeValueSeconds(5));
|
timeValueSeconds(5));
|
||||||
|
|
|
@ -5,18 +5,16 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.support.http;
|
package org.elasticsearch.watcher.support.http;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import com.squareup.okhttp.mockwebserver.MockResponse;
|
import com.squareup.okhttp.mockwebserver.MockResponse;
|
||||||
import com.squareup.okhttp.mockwebserver.MockWebServer;
|
import com.squareup.okhttp.mockwebserver.MockWebServer;
|
||||||
import com.squareup.okhttp.mockwebserver.RecordedRequest;
|
import com.squareup.okhttp.mockwebserver.RecordedRequest;
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchException;
|
import org.elasticsearch.ElasticsearchException;
|
||||||
import org.elasticsearch.ExceptionsHelper;
|
import org.elasticsearch.ExceptionsHelper;
|
||||||
import org.elasticsearch.common.io.PathUtils;
|
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.env.Environment;
|
import org.elasticsearch.env.Environment;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.test.junit.annotations.Network;
|
import org.elasticsearch.test.junit.annotations.Network;
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthFactory;
|
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
||||||
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuth;
|
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuth;
|
||||||
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
||||||
|
@ -25,8 +23,6 @@ import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import javax.net.ssl.SSLSocket;
|
|
||||||
import javax.net.ssl.SSLSocketFactory;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.BindException;
|
import java.net.BindException;
|
||||||
import java.net.InetAddress;
|
import java.net.InetAddress;
|
||||||
|
@ -36,7 +32,14 @@ import java.nio.charset.StandardCharsets;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.security.UnrecoverableKeyException;
|
import java.security.UnrecoverableKeyException;
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.*;
|
import javax.net.ssl.SSLSocket;
|
||||||
|
import javax.net.ssl.SSLSocketFactory;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
|
import static org.hamcrest.Matchers.nullValue;
|
||||||
import static org.hamcrest.core.Is.is;
|
import static org.hamcrest.core.Is.is;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -54,7 +57,7 @@ public class HttpClientTests extends ESTestCase {
|
||||||
@Before
|
@Before
|
||||||
public void init() throws Exception {
|
public void init() throws Exception {
|
||||||
secretService = new SecretService.PlainText();
|
secretService = new SecretService.PlainText();
|
||||||
authRegistry = new HttpAuthRegistry(ImmutableMap.<String, HttpAuthFactory>of(BasicAuth.TYPE, new BasicAuthFactory(secretService)));
|
authRegistry = new HttpAuthRegistry(singletonMap(BasicAuth.TYPE, new BasicAuthFactory(secretService)));
|
||||||
for (webPort = 9200; webPort < 9300; webPort++) {
|
for (webPort = 9200; webPort < 9300; webPort++) {
|
||||||
try {
|
try {
|
||||||
webServer = new MockWebServer();
|
webServer = new MockWebServer();
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.support.http;
|
package org.elasticsearch.watcher.support.http;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.common.xcontent.ToXContent;
|
import org.elasticsearch.common.xcontent.ToXContent;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
|
@ -13,7 +12,6 @@ import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.common.xcontent.XContentType;
|
import org.elasticsearch.common.xcontent.XContentType;
|
||||||
import org.elasticsearch.common.xcontent.json.JsonXContent;
|
import org.elasticsearch.common.xcontent.json.JsonXContent;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthFactory;
|
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
||||||
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuth;
|
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuth;
|
||||||
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
||||||
|
@ -25,8 +23,12 @@ import org.junit.Test;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.hasEntry;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -39,7 +41,7 @@ public class HttpRequestTemplateTests extends ESTestCase {
|
||||||
HttpRequestTemplate template = HttpRequestTemplate.builder("_host", 1234)
|
HttpRequestTemplate template = HttpRequestTemplate.builder("_host", 1234)
|
||||||
.body(XContentBuilder.builder(type.xContent()).startObject().endObject())
|
.body(XContentBuilder.builder(type.xContent()).startObject().endObject())
|
||||||
.build();
|
.build();
|
||||||
HttpRequest request = template.render(new MockTextTemplateEngine(), ImmutableMap.<String, Object>of());
|
HttpRequest request = template.render(new MockTextTemplateEngine(), emptyMap());
|
||||||
assertThat(request.headers, hasEntry(HttpHeaders.Names.CONTENT_TYPE, type.restContentType()));
|
assertThat(request.headers, hasEntry(HttpHeaders.Names.CONTENT_TYPE, type.restContentType()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,7 +50,7 @@ public class HttpRequestTemplateTests extends ESTestCase {
|
||||||
HttpRequestTemplate template = HttpRequestTemplate.builder("_host", 1234)
|
HttpRequestTemplate template = HttpRequestTemplate.builder("_host", 1234)
|
||||||
.body("_body")
|
.body("_body")
|
||||||
.build();
|
.build();
|
||||||
HttpRequest request = template.render(new MockTextTemplateEngine(), ImmutableMap.<String, Object>of());
|
HttpRequest request = template.render(new MockTextTemplateEngine(), emptyMap());
|
||||||
assertThat(request.headers.size(), is(0));
|
assertThat(request.headers.size(), is(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,7 +92,7 @@ public class HttpRequestTemplateTests extends ESTestCase {
|
||||||
|
|
||||||
HttpRequestTemplate template = builder.build();
|
HttpRequestTemplate template = builder.build();
|
||||||
|
|
||||||
HttpAuthRegistry registry = new HttpAuthRegistry(ImmutableMap.<String, HttpAuthFactory>of(BasicAuth.TYPE, new BasicAuthFactory(new SecretService.PlainText())));
|
HttpAuthRegistry registry = new HttpAuthRegistry(singletonMap(BasicAuth.TYPE, new BasicAuthFactory(new SecretService.PlainText())));
|
||||||
HttpRequestTemplate.Parser parser = new HttpRequestTemplate.Parser(registry);
|
HttpRequestTemplate.Parser parser = new HttpRequestTemplate.Parser(registry);
|
||||||
|
|
||||||
XContentBuilder xContentBuilder = template.toXContent(jsonBuilder(), ToXContent.EMPTY_PARAMS);
|
XContentBuilder xContentBuilder = template.toXContent(jsonBuilder(), ToXContent.EMPTY_PARAMS);
|
||||||
|
|
|
@ -7,7 +7,6 @@ package org.elasticsearch.watcher.support.http;
|
||||||
|
|
||||||
import org.elasticsearch.common.bytes.BytesArray;
|
import org.elasticsearch.common.bytes.BytesArray;
|
||||||
import org.elasticsearch.common.bytes.BytesReference;
|
import org.elasticsearch.common.bytes.BytesReference;
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
|
@ -16,6 +15,8 @@ import org.junit.Test;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.watcher.test.WatcherTestUtils.xContentParser;
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.xContentParser;
|
||||||
import static org.hamcrest.CoreMatchers.nullValue;
|
import static org.hamcrest.CoreMatchers.nullValue;
|
||||||
|
@ -31,9 +32,9 @@ public class HttpResponseTests extends ESTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testParse_SelfGenerated() throws Exception {
|
public void testParse_SelfGenerated() throws Exception {
|
||||||
int status = randomIntBetween(200, 600);
|
int status = randomIntBetween(200, 600);
|
||||||
ImmutableMap<String, String[]> headers = ImmutableMap.of();
|
Map<String, String[]> headers = emptyMap();
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
headers = ImmutableMap.of("key", new String[] { "value" });
|
headers = singletonMap("key", new String[] { "value" });
|
||||||
}
|
}
|
||||||
String body = randomBoolean() ? "body" : null;
|
String body = randomBoolean() ? "body" : null;
|
||||||
final HttpResponse response;
|
final HttpResponse response;
|
||||||
|
|
|
@ -6,7 +6,6 @@
|
||||||
package org.elasticsearch.watcher.support.text;
|
package org.elasticsearch.watcher.support.text;
|
||||||
|
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.bytes.BytesReference;
|
import org.elasticsearch.common.bytes.BytesReference;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
@ -21,11 +20,16 @@ import org.elasticsearch.watcher.support.text.xmustache.XMustacheTextTemplateEng
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
|
import static java.util.Collections.unmodifiableMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.watcher.support.Exceptions.illegalArgument;
|
import static org.elasticsearch.watcher.support.Exceptions.illegalArgument;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
@ -49,9 +53,11 @@ public class TextTemplateTests extends ESTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testRender() throws Exception {
|
public void testRender() throws Exception {
|
||||||
String templateText = "_template";
|
String templateText = "_template";
|
||||||
Map<String, Object> params = ImmutableMap.<String, Object>of("param_key", "param_val");
|
Map<String, Object> params = singletonMap("param_key", "param_val");
|
||||||
Map<String, Object> model = ImmutableMap.<String, Object>of("model_key", "model_val");
|
Map<String, Object> model = singletonMap("model_key", "model_val");
|
||||||
Map<String, Object> merged = ImmutableMap.<String, Object>builder().putAll(params).putAll(model).build();
|
Map<String, Object> merged = new HashMap<>(params);
|
||||||
|
merged.putAll(model);
|
||||||
|
merged = unmodifiableMap(merged);
|
||||||
ScriptType type = randomFrom(ScriptType.values());
|
ScriptType type = randomFrom(ScriptType.values());
|
||||||
|
|
||||||
when(proxy.executable(new org.elasticsearch.script.Template(templateText, type, lang, null, merged))).thenReturn(script);
|
when(proxy.executable(new org.elasticsearch.script.Template(templateText, type, lang, null, merged))).thenReturn(script);
|
||||||
|
@ -64,8 +70,8 @@ public class TextTemplateTests extends ESTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testRender_OverridingModel() throws Exception {
|
public void testRender_OverridingModel() throws Exception {
|
||||||
String templateText = "_template";
|
String templateText = "_template";
|
||||||
Map<String, Object> params = ImmutableMap.<String, Object>of("key", "param_val");
|
Map<String, Object> params = singletonMap("key", "param_val");
|
||||||
Map<String, Object> model = ImmutableMap.<String, Object>of("key", "model_val");
|
Map<String, Object> model = singletonMap("key", "model_val");
|
||||||
ScriptType scriptType = randomFrom(ScriptType.values());
|
ScriptType scriptType = randomFrom(ScriptType.values());
|
||||||
|
|
||||||
when(proxy.executable(new org.elasticsearch.script.Template(templateText, scriptType, lang, null, model))).thenReturn(script);
|
when(proxy.executable(new org.elasticsearch.script.Template(templateText, scriptType, lang, null, model))).thenReturn(script);
|
||||||
|
@ -78,7 +84,7 @@ public class TextTemplateTests extends ESTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testRender_Defaults() throws Exception {
|
public void testRender_Defaults() throws Exception {
|
||||||
String templateText = "_template";
|
String templateText = "_template";
|
||||||
Map<String, Object> model = ImmutableMap.<String, Object>of("key", "model_val");
|
Map<String, Object> model = singletonMap("key", "model_val");
|
||||||
|
|
||||||
when(proxy.executable(new org.elasticsearch.script.Template(templateText, ScriptType.INLINE, lang, null, model))).thenReturn(script);
|
when(proxy.executable(new org.elasticsearch.script.Template(templateText, ScriptType.INLINE, lang, null, model))).thenReturn(script);
|
||||||
when(script.run()).thenReturn("rendered_text");
|
when(script.run()).thenReturn("rendered_text");
|
||||||
|
@ -90,7 +96,7 @@ public class TextTemplateTests extends ESTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testParser() throws Exception {
|
public void testParser() throws Exception {
|
||||||
ScriptType type = randomScriptType();
|
ScriptType type = randomScriptType();
|
||||||
TextTemplate template = templateBuilder(type, "_template").params(ImmutableMap.<String, Object>of("param_key", "param_val")).build();
|
TextTemplate template = templateBuilder(type, "_template").params(singletonMap("param_key", "param_val")).build();
|
||||||
XContentBuilder builder = jsonBuilder().startObject();
|
XContentBuilder builder = jsonBuilder().startObject();
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case INLINE:
|
case INLINE:
|
||||||
|
@ -114,7 +120,7 @@ public class TextTemplateTests extends ESTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testParser_ParserSelfGenerated() throws Exception {
|
public void testParser_ParserSelfGenerated() throws Exception {
|
||||||
TextTemplate template = templateBuilder(randomScriptType(), "_template").params(ImmutableMap.<String, Object>of("param_key", "param_val")).build();
|
TextTemplate template = templateBuilder(randomScriptType(), "_template").params(singletonMap("param_key", "param_val")).build();
|
||||||
|
|
||||||
XContentBuilder builder = jsonBuilder().value(template);
|
XContentBuilder builder = jsonBuilder().value(template);
|
||||||
BytesReference bytes = builder.bytes();
|
BytesReference bytes = builder.bytes();
|
||||||
|
|
|
@ -6,7 +6,6 @@
|
||||||
package org.elasticsearch.watcher.support.text.xmustache;
|
package org.elasticsearch.watcher.support.text.xmustache;
|
||||||
|
|
||||||
import com.fasterxml.jackson.core.io.JsonStringEncoder;
|
import com.fasterxml.jackson.core.io.JsonStringEncoder;
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.elasticsearch.common.bytes.BytesReference;
|
import org.elasticsearch.common.bytes.BytesReference;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
@ -26,6 +25,7 @@ import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import static java.util.Collections.singleton;
|
import static java.util.Collections.singleton;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.util.set.Sets.newHashSet;
|
import static org.elasticsearch.common.util.set.Sets.newHashSet;
|
||||||
import static org.hamcrest.Matchers.both;
|
import static org.hamcrest.Matchers.both;
|
||||||
import static org.hamcrest.Matchers.containsString;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
@ -93,8 +93,8 @@ public class XMustacheTests extends ESTestCase {
|
||||||
CompiledScript mustache = new CompiledScript(ScriptService.ScriptType.INLINE, "inline", "mustache", engine.compile(template));
|
CompiledScript mustache = new CompiledScript(ScriptService.ScriptType.INLINE, "inline", "mustache", engine.compile(template));
|
||||||
Map<String, Object> vars = new HashMap<>();
|
Map<String, Object> vars = new HashMap<>();
|
||||||
Object data = randomFrom(
|
Object data = randomFrom(
|
||||||
new Map[] { ImmutableMap.<String, Object>of("key", "foo"), ImmutableMap.<String, Object>of("key", "bar") },
|
new Map[] { singletonMap("key", "foo"), singletonMap("key", "bar") },
|
||||||
Arrays.asList(ImmutableMap.<String, Object>of("key", "foo"), ImmutableMap.<String, Object>of("key", "bar")));
|
Arrays.asList(singletonMap("key", "foo"), singletonMap("key", "bar")));
|
||||||
vars.put("data", data);
|
vars.put("data", data);
|
||||||
Object output = engine.execute(mustache, vars);
|
Object output = engine.execute(mustache, vars);
|
||||||
assertThat(output, notNullValue());
|
assertThat(output, notNullValue());
|
||||||
|
@ -103,7 +103,7 @@ public class XMustacheTests extends ESTestCase {
|
||||||
assertThat(bytes.toUtf8(), equalTo("foo bar"));
|
assertThat(bytes.toUtf8(), equalTo("foo bar"));
|
||||||
|
|
||||||
// HashSet iteration order isn't fixed
|
// HashSet iteration order isn't fixed
|
||||||
vars.put("data", newHashSet(ImmutableMap.<String, Object>of("key", "foo"), ImmutableMap.<String, Object>of("key", "bar")));
|
vars.put("data", newHashSet(singletonMap("key", "foo"), singletonMap("key", "bar")));
|
||||||
output = engine.execute(mustache, vars);
|
output = engine.execute(mustache, vars);
|
||||||
assertThat(output, notNullValue());
|
assertThat(output, notNullValue());
|
||||||
assertThat(output, instanceOf(BytesReference.class));
|
assertThat(output, instanceOf(BytesReference.class));
|
||||||
|
|
|
@ -5,12 +5,16 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.support.xcontent;
|
package org.elasticsearch.watcher.support.xcontent;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.hamcrest.CoreMatchers.nullValue;
|
import static org.hamcrest.CoreMatchers.nullValue;
|
||||||
import static org.hamcrest.Matchers.is;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
|
||||||
|
@ -21,9 +25,7 @@ public class MapPathTests extends ESTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testEval() throws Exception {
|
public void testEval() throws Exception {
|
||||||
Map<String, Object> map = ImmutableMap.<String, Object>builder()
|
Map<String, Object> map = singletonMap("key", "value");
|
||||||
.put("key", "value")
|
|
||||||
.build();
|
|
||||||
|
|
||||||
assertThat(ObjectPath.eval("key", map), is((Object) "value"));
|
assertThat(ObjectPath.eval("key", map), is((Object) "value"));
|
||||||
assertThat(ObjectPath.eval("key1", map), nullValue());
|
assertThat(ObjectPath.eval("key1", map), nullValue());
|
||||||
|
@ -32,9 +34,7 @@ public class MapPathTests extends ESTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testEval_List() throws Exception {
|
public void testEval_List() throws Exception {
|
||||||
List list = Arrays.asList(1, 2, 3, 4);
|
List list = Arrays.asList(1, 2, 3, 4);
|
||||||
Map<String, Object> map = ImmutableMap.<String, Object>builder()
|
Map<String, Object> map = singletonMap("key", list);
|
||||||
.put("key", list)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
int index = randomInt(3);
|
int index = randomInt(3);
|
||||||
assertThat(ObjectPath.eval("key." + index, map), is(list.get(index)));
|
assertThat(ObjectPath.eval("key." + index, map), is(list.get(index)));
|
||||||
|
@ -43,9 +43,7 @@ public class MapPathTests extends ESTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testEval_Array() throws Exception {
|
public void testEval_Array() throws Exception {
|
||||||
int[] array = new int[] { 1, 2, 3, 4 };
|
int[] array = new int[] { 1, 2, 3, 4 };
|
||||||
Map<String, Object> map = ImmutableMap.<String, Object>builder()
|
Map<String, Object> map = singletonMap("key", array);
|
||||||
.put("key", array)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
int index = randomInt(3);
|
int index = randomInt(3);
|
||||||
assertThat(((Number) ObjectPath.eval("key." + index, map)).intValue(), is(array[index]));
|
assertThat(((Number) ObjectPath.eval("key." + index, map)).intValue(), is(array[index]));
|
||||||
|
@ -53,9 +51,7 @@ public class MapPathTests extends ESTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testEval_Map() throws Exception {
|
public void testEval_Map() throws Exception {
|
||||||
Map<String, Object> map = ImmutableMap.<String, Object>builder()
|
Map<String, Object> map = singletonMap("a", singletonMap("b", "val"));
|
||||||
.put("a", ImmutableMap.of("b", "val"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
assertThat(ObjectPath.eval("a.b", map), is((Object) "val"));
|
assertThat(ObjectPath.eval("a.b", map), is((Object) "val"));
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.test;
|
package org.elasticsearch.watcher.test;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.action.search.SearchRequest;
|
import org.elasticsearch.action.search.SearchRequest;
|
||||||
import org.elasticsearch.action.search.SearchType;
|
import org.elasticsearch.action.search.SearchType;
|
||||||
import org.elasticsearch.action.support.IndicesOptions;
|
import org.elasticsearch.action.support.IndicesOptions;
|
||||||
|
@ -15,7 +14,12 @@ import org.elasticsearch.common.bytes.BytesReference;
|
||||||
import org.elasticsearch.common.logging.ESLogger;
|
import org.elasticsearch.common.logging.ESLogger;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.common.xcontent.*;
|
import org.elasticsearch.common.xcontent.XContent;
|
||||||
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
|
import org.elasticsearch.common.xcontent.XContentFactory;
|
||||||
|
import org.elasticsearch.common.xcontent.XContentHelper;
|
||||||
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
import org.elasticsearch.common.xcontent.XContentType;
|
||||||
import org.elasticsearch.env.Environment;
|
import org.elasticsearch.env.Environment;
|
||||||
import org.elasticsearch.script.ScriptContextRegistry;
|
import org.elasticsearch.script.ScriptContextRegistry;
|
||||||
import org.elasticsearch.script.ScriptEngineService;
|
import org.elasticsearch.script.ScriptEngineService;
|
||||||
|
@ -29,7 +33,11 @@ import org.elasticsearch.watcher.actions.ActionWrapper;
|
||||||
import org.elasticsearch.watcher.actions.ExecutableActions;
|
import org.elasticsearch.watcher.actions.ExecutableActions;
|
||||||
import org.elasticsearch.watcher.actions.email.EmailAction;
|
import org.elasticsearch.watcher.actions.email.EmailAction;
|
||||||
import org.elasticsearch.watcher.actions.email.ExecutableEmailAction;
|
import org.elasticsearch.watcher.actions.email.ExecutableEmailAction;
|
||||||
import org.elasticsearch.watcher.actions.email.service.*;
|
import org.elasticsearch.watcher.actions.email.service.Authentication;
|
||||||
|
import org.elasticsearch.watcher.actions.email.service.EmailService;
|
||||||
|
import org.elasticsearch.watcher.actions.email.service.EmailTemplate;
|
||||||
|
import org.elasticsearch.watcher.actions.email.service.HtmlSanitizer;
|
||||||
|
import org.elasticsearch.watcher.actions.email.service.Profile;
|
||||||
import org.elasticsearch.watcher.actions.webhook.ExecutableWebhookAction;
|
import org.elasticsearch.watcher.actions.webhook.ExecutableWebhookAction;
|
||||||
import org.elasticsearch.watcher.actions.webhook.WebhookAction;
|
import org.elasticsearch.watcher.actions.webhook.WebhookAction;
|
||||||
import org.elasticsearch.watcher.condition.script.ExecutableScriptCondition;
|
import org.elasticsearch.watcher.condition.script.ExecutableScriptCondition;
|
||||||
|
@ -65,12 +73,21 @@ import org.elasticsearch.watcher.watch.WatchStatus;
|
||||||
import org.hamcrest.Matcher;
|
import org.hamcrest.Matcher;
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
|
|
||||||
import javax.mail.internet.AddressException;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import javax.mail.internet.AddressException;
|
||||||
|
|
||||||
import static com.carrotsearch.randomizedtesting.RandomizedTest.randomInt;
|
import static com.carrotsearch.randomizedtesting.RandomizedTest.randomInt;
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
import static org.apache.lucene.util.LuceneTestCase.createTempDir;
|
import static org.apache.lucene.util.LuceneTestCase.createTempDir;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
||||||
import static org.elasticsearch.search.builder.SearchSourceBuilder.searchSource;
|
import static org.elasticsearch.search.builder.SearchSourceBuilder.searchSource;
|
||||||
|
@ -85,7 +102,7 @@ import static org.mockito.Mockito.when;
|
||||||
*/
|
*/
|
||||||
public final class WatcherTestUtils {
|
public final class WatcherTestUtils {
|
||||||
|
|
||||||
public static final Payload EMPTY_PAYLOAD = new Payload.Simple(ImmutableMap.<String, Object>of());
|
public static final Payload EMPTY_PAYLOAD = new Payload.Simple(emptyMap());
|
||||||
|
|
||||||
private WatcherTestUtils() {
|
private WatcherTestUtils() {
|
||||||
}
|
}
|
||||||
|
@ -214,6 +231,9 @@ public final class WatcherTestUtils {
|
||||||
when(licenseService.enabled()).thenReturn(true);
|
when(licenseService.enabled()).thenReturn(true);
|
||||||
|
|
||||||
DateTime now = DateTime.now(UTC);
|
DateTime now = DateTime.now(UTC);
|
||||||
|
Map<String, ActionStatus> statuses = new HashMap<>();
|
||||||
|
statuses.put("_webhook", new ActionStatus(now));
|
||||||
|
statuses.put("_email", new ActionStatus(now));
|
||||||
return new Watch(
|
return new Watch(
|
||||||
watchName,
|
watchName,
|
||||||
new ScheduleTrigger(new CronSchedule("0/5 * * * * ? *")),
|
new ScheduleTrigger(new CronSchedule("0/5 * * * * ? *")),
|
||||||
|
@ -223,10 +243,7 @@ public final class WatcherTestUtils {
|
||||||
new TimeValue(0),
|
new TimeValue(0),
|
||||||
new ExecutableActions(actions),
|
new ExecutableActions(actions),
|
||||||
metadata,
|
metadata,
|
||||||
new WatchStatus(now, ImmutableMap.<String, ActionStatus>builder()
|
new WatchStatus(now, statuses));
|
||||||
.put("_webhook", new ActionStatus(now))
|
|
||||||
.put("_email", new ActionStatus(now))
|
|
||||||
.build()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ScriptServiceProxy getScriptServiceProxy(ThreadPool tp) throws Exception {
|
public static ScriptServiceProxy getScriptServiceProxy(ThreadPool tp) throws Exception {
|
||||||
|
|
|
@ -12,14 +12,23 @@ import org.elasticsearch.watcher.support.clock.SystemClock;
|
||||||
import org.elasticsearch.watcher.trigger.Trigger;
|
import org.elasticsearch.watcher.trigger.Trigger;
|
||||||
import org.elasticsearch.watcher.trigger.TriggerEngine;
|
import org.elasticsearch.watcher.trigger.TriggerEngine;
|
||||||
import org.elasticsearch.watcher.trigger.TriggerEvent;
|
import org.elasticsearch.watcher.trigger.TriggerEvent;
|
||||||
import org.elasticsearch.watcher.trigger.schedule.*;
|
import org.elasticsearch.watcher.trigger.schedule.Schedule;
|
||||||
|
import org.elasticsearch.watcher.trigger.schedule.ScheduleRegistry;
|
||||||
|
import org.elasticsearch.watcher.trigger.schedule.ScheduleTrigger;
|
||||||
|
import org.elasticsearch.watcher.trigger.schedule.ScheduleTriggerEngine;
|
||||||
|
import org.elasticsearch.watcher.trigger.schedule.ScheduleTriggerEvent;
|
||||||
import org.elasticsearch.watcher.trigger.schedule.engine.SchedulerScheduleTriggerEngine;
|
import org.elasticsearch.watcher.trigger.schedule.engine.SchedulerScheduleTriggerEngine;
|
||||||
import org.elasticsearch.watcher.trigger.schedule.engine.TickerScheduleTriggerEngine;
|
import org.elasticsearch.watcher.trigger.schedule.engine.TickerScheduleTriggerEngine;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
import static org.elasticsearch.watcher.trigger.schedule.Schedules.interval;
|
import static org.elasticsearch.watcher.trigger.schedule.Schedules.interval;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -54,7 +63,7 @@ public class ScheduleEngineTriggerBenchmark {
|
||||||
for (int i = 0; i < numWatches; i++) {
|
for (int i = 0; i < numWatches; i++) {
|
||||||
jobs.add(new SimpleJob("job_" + i, interval(interval + "s")));
|
jobs.add(new SimpleJob("job_" + i, interval(interval + "s")));
|
||||||
}
|
}
|
||||||
ScheduleRegistry scheduleRegistry = new ScheduleRegistry(Collections.<String, Schedule.Parser>emptyMap());
|
ScheduleRegistry scheduleRegistry = new ScheduleRegistry(emptyMap());
|
||||||
List<String> impls = new ArrayList<>(Arrays.asList(new String[]{"schedule", "ticker"}));
|
List<String> impls = new ArrayList<>(Arrays.asList(new String[]{"schedule", "ticker"}));
|
||||||
Collections.shuffle(impls);
|
Collections.shuffle(impls);
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.transform.chain;
|
package org.elasticsearch.watcher.transform.chain;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.common.logging.ESLogger;
|
import org.elasticsearch.common.logging.ESLogger;
|
||||||
import org.elasticsearch.common.logging.Loggers;
|
import org.elasticsearch.common.logging.Loggers;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
|
@ -26,8 +25,15 @@ import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.contains;
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.hasKey;
|
||||||
|
import static org.hamcrest.Matchers.hasSize;
|
||||||
|
import static org.hamcrest.Matchers.instanceOf;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -110,10 +116,7 @@ public class ChainTransformTests extends ESTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testParser() throws Exception {
|
public void testParser() throws Exception {
|
||||||
Map<String, TransformFactory> factories = ImmutableMap.<String, TransformFactory>builder()
|
TransformRegistry registry = new TransformRegistry(singletonMap("named", new NamedExecutableTransform.Factory(logger)));
|
||||||
.put("named", new NamedExecutableTransform.Factory(logger))
|
|
||||||
.build();
|
|
||||||
TransformRegistry registry = new TransformRegistry(factories);
|
|
||||||
|
|
||||||
ChainTransformFactory transformParser = new ChainTransformFactory(registry);
|
ChainTransformFactory transformParser = new ChainTransformFactory(registry);
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.transform.search;
|
package org.elasticsearch.watcher.transform.search;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptRequest;
|
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptRequest;
|
||||||
import org.elasticsearch.action.search.SearchRequest;
|
import org.elasticsearch.action.search.SearchRequest;
|
||||||
import org.elasticsearch.action.search.SearchResponse;
|
import org.elasticsearch.action.search.SearchResponse;
|
||||||
|
@ -22,7 +21,6 @@ import org.elasticsearch.common.xcontent.support.XContentMapValues;
|
||||||
import org.elasticsearch.search.builder.SearchSourceBuilder;
|
import org.elasticsearch.search.builder.SearchSourceBuilder;
|
||||||
import org.elasticsearch.test.ESIntegTestCase;
|
import org.elasticsearch.test.ESIntegTestCase;
|
||||||
import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
||||||
import org.elasticsearch.watcher.actions.ActionStatus;
|
|
||||||
import org.elasticsearch.watcher.actions.ActionWrapper;
|
import org.elasticsearch.watcher.actions.ActionWrapper;
|
||||||
import org.elasticsearch.watcher.actions.ExecutableActions;
|
import org.elasticsearch.watcher.actions.ExecutableActions;
|
||||||
import org.elasticsearch.watcher.condition.always.ExecutableAlwaysCondition;
|
import org.elasticsearch.watcher.condition.always.ExecutableAlwaysCondition;
|
||||||
|
@ -52,15 +50,29 @@ import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyMap;
|
||||||
import static org.elasticsearch.common.settings.Settings.settingsBuilder;
|
import static org.elasticsearch.common.settings.Settings.settingsBuilder;
|
||||||
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.*;
|
import static org.elasticsearch.index.query.QueryBuilders.boolQuery;
|
||||||
|
import static org.elasticsearch.index.query.QueryBuilders.constantScoreQuery;
|
||||||
|
import static org.elasticsearch.index.query.QueryBuilders.matchQuery;
|
||||||
|
import static org.elasticsearch.index.query.QueryBuilders.rangeQuery;
|
||||||
|
import static org.elasticsearch.index.query.QueryBuilders.termQuery;
|
||||||
import static org.elasticsearch.search.builder.SearchSourceBuilder.searchSource;
|
import static org.elasticsearch.search.builder.SearchSourceBuilder.searchSource;
|
||||||
import static org.elasticsearch.test.ESIntegTestCase.Scope.SUITE;
|
import static org.elasticsearch.test.ESIntegTestCase.Scope.SUITE;
|
||||||
import static org.elasticsearch.watcher.support.WatcherDateTimeUtils.parseDate;
|
import static org.elasticsearch.watcher.support.WatcherDateTimeUtils.parseDate;
|
||||||
import static org.elasticsearch.watcher.test.WatcherTestUtils.*;
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.EMPTY_PAYLOAD;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.areJsonEquivalent;
|
||||||
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.getRandomSupportedSearchType;
|
||||||
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.mockExecutionContext;
|
||||||
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.simplePayload;
|
||||||
|
import static org.hamcrest.Matchers.arrayContainingInAnyOrder;
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
|
import static org.hamcrest.Matchers.startsWith;
|
||||||
import static org.joda.time.DateTimeZone.UTC;
|
import static org.joda.time.DateTimeZone.UTC;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -425,7 +437,7 @@ public class SearchTransformTests extends ESIntegTestCase {
|
||||||
null,
|
null,
|
||||||
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
new ExecutableActions(new ArrayList<ActionWrapper>()),
|
||||||
null,
|
null,
|
||||||
new WatchStatus( new DateTime(40000, UTC), ImmutableMap.<String, ActionStatus>of())),
|
new WatchStatus( new DateTime(40000, UTC), emptyMap())),
|
||||||
new DateTime(60000, UTC),
|
new DateTime(60000, UTC),
|
||||||
new ScheduleTriggerEvent("test-watch", new DateTime(60000, UTC), new DateTime(60000, UTC)),
|
new ScheduleTriggerEvent("test-watch", new DateTime(60000, UTC), new DateTime(60000, UTC)),
|
||||||
timeValueSeconds(5));
|
timeValueSeconds(5));
|
||||||
|
|
|
@ -6,9 +6,6 @@
|
||||||
package org.elasticsearch.watcher.transport.action.execute;
|
package org.elasticsearch.watcher.transport.action.execute;
|
||||||
|
|
||||||
import org.elasticsearch.action.ActionRequestValidationException;
|
import org.elasticsearch.action.ActionRequestValidationException;
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
import org.joda.time.DateTime;
|
|
||||||
import org.joda.time.DateTimeZone;
|
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.watcher.actions.ActionStatus;
|
import org.elasticsearch.watcher.actions.ActionStatus;
|
||||||
import org.elasticsearch.watcher.client.WatcherClient;
|
import org.elasticsearch.watcher.client.WatcherClient;
|
||||||
|
@ -25,11 +22,14 @@ import org.elasticsearch.watcher.transport.actions.get.GetWatchResponse;
|
||||||
import org.elasticsearch.watcher.transport.actions.put.PutWatchResponse;
|
import org.elasticsearch.watcher.transport.actions.put.PutWatchResponse;
|
||||||
import org.elasticsearch.watcher.trigger.schedule.ScheduleTriggerEvent;
|
import org.elasticsearch.watcher.trigger.schedule.ScheduleTriggerEvent;
|
||||||
import org.elasticsearch.watcher.watch.WatchStatus;
|
import org.elasticsearch.watcher.watch.WatchStatus;
|
||||||
|
import org.joda.time.DateTime;
|
||||||
|
import org.joda.time.DateTimeZone;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
import static org.elasticsearch.watcher.actions.ActionBuilders.loggingAction;
|
import static org.elasticsearch.watcher.actions.ActionBuilders.loggingAction;
|
||||||
import static org.elasticsearch.watcher.client.WatchSourceBuilders.watchBuilder;
|
import static org.elasticsearch.watcher.client.WatchSourceBuilders.watchBuilder;
|
||||||
import static org.elasticsearch.watcher.condition.ConditionBuilders.alwaysCondition;
|
import static org.elasticsearch.watcher.condition.ConditionBuilders.alwaysCondition;
|
||||||
|
@ -180,7 +180,7 @@ public class ExecuteWatchTests extends AbstractWatcherIntegrationTestCase {
|
||||||
assertThat(putWatchResponse.isCreated(), is(true));
|
assertThat(putWatchResponse.isCreated(), is(true));
|
||||||
|
|
||||||
ExecuteWatchResponse response = watcherClient.prepareExecuteWatch("_id")
|
ExecuteWatchResponse response = watcherClient.prepareExecuteWatch("_id")
|
||||||
.setAlternativeInput(ImmutableMap.<String, Object>of("foo1", "bar1"))
|
.setAlternativeInput(singletonMap("foo1", "bar1"))
|
||||||
.get();
|
.get();
|
||||||
assertThat(response, notNullValue());
|
assertThat(response, notNullValue());
|
||||||
assertThat(response.getRecordId(), notNullValue());
|
assertThat(response.getRecordId(), notNullValue());
|
||||||
|
|
|
@ -5,8 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.watch;
|
package org.elasticsearch.watcher.watch;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.bytes.BytesReference;
|
import org.elasticsearch.common.bytes.BytesReference;
|
||||||
import org.elasticsearch.common.logging.ESLogger;
|
import org.elasticsearch.common.logging.ESLogger;
|
||||||
|
@ -72,7 +70,6 @@ import org.elasticsearch.watcher.support.clock.SystemClock;
|
||||||
import org.elasticsearch.watcher.support.http.HttpClient;
|
import org.elasticsearch.watcher.support.http.HttpClient;
|
||||||
import org.elasticsearch.watcher.support.http.HttpMethod;
|
import org.elasticsearch.watcher.support.http.HttpMethod;
|
||||||
import org.elasticsearch.watcher.support.http.HttpRequestTemplate;
|
import org.elasticsearch.watcher.support.http.HttpRequestTemplate;
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthFactory;
|
|
||||||
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
import org.elasticsearch.watcher.support.http.auth.HttpAuthRegistry;
|
||||||
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
import org.elasticsearch.watcher.support.http.auth.basic.BasicAuthFactory;
|
||||||
import org.elasticsearch.watcher.support.init.proxy.ClientProxy;
|
import org.elasticsearch.watcher.support.init.proxy.ClientProxy;
|
||||||
|
@ -121,10 +118,13 @@ import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import static java.util.Collections.singleton;
|
import static java.util.Collections.singleton;
|
||||||
|
import static java.util.Collections.singletonMap;
|
||||||
|
import static java.util.Collections.unmodifiableMap;
|
||||||
import static org.elasticsearch.watcher.input.InputBuilders.searchInput;
|
import static org.elasticsearch.watcher.input.InputBuilders.searchInput;
|
||||||
import static org.elasticsearch.watcher.test.WatcherTestUtils.matchAllRequest;
|
import static org.elasticsearch.watcher.test.WatcherTestUtils.matchAllRequest;
|
||||||
import static org.elasticsearch.watcher.trigger.TriggerBuilders.schedule;
|
import static org.elasticsearch.watcher.trigger.TriggerBuilders.schedule;
|
||||||
|
@ -160,7 +160,7 @@ public class WatchTests extends ESTestCase {
|
||||||
htmlSanitizer = mock(HtmlSanitizer.class);
|
htmlSanitizer = mock(HtmlSanitizer.class);
|
||||||
secretService = mock(SecretService.class);
|
secretService = mock(SecretService.class);
|
||||||
licenseService = mock(LicenseService.class);
|
licenseService = mock(LicenseService.class);
|
||||||
authRegistry = new HttpAuthRegistry(ImmutableMap.of("basic", (HttpAuthFactory) new BasicAuthFactory(secretService)));
|
authRegistry = new HttpAuthRegistry(singletonMap("basic", new BasicAuthFactory(secretService)));
|
||||||
logger = Loggers.getLogger(WatchTests.class);
|
logger = Loggers.getLogger(WatchTests.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -189,13 +189,13 @@ public class WatchTests extends ESTestCase {
|
||||||
ExecutableActions actions = randomActions();
|
ExecutableActions actions = randomActions();
|
||||||
ActionRegistry actionRegistry = registry(actions, transformRegistry);
|
ActionRegistry actionRegistry = registry(actions, transformRegistry);
|
||||||
|
|
||||||
Map<String, Object> metadata = ImmutableMap.<String, Object>of("_key", "_val");
|
Map<String, Object> metadata = singletonMap("_key", "_val");
|
||||||
|
|
||||||
ImmutableMap.Builder<String, ActionStatus> actionsStatuses = ImmutableMap.builder();
|
Map<String, ActionStatus> actionsStatuses = new HashMap<>();
|
||||||
for (ActionWrapper action : actions) {
|
for (ActionWrapper action : actions) {
|
||||||
actionsStatuses.put(action.id(), new ActionStatus(now));
|
actionsStatuses.put(action.id(), new ActionStatus(now));
|
||||||
}
|
}
|
||||||
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), actionsStatuses.build());
|
WatchStatus watchStatus = new WatchStatus(clock.nowUTC(), unmodifiableMap(actionsStatuses));
|
||||||
|
|
||||||
TimeValue throttlePeriod = randomBoolean() ? null : TimeValue.timeValueSeconds(randomIntBetween(5, 10));
|
TimeValue throttlePeriod = randomBoolean() ? null : TimeValue.timeValueSeconds(randomIntBetween(5, 10));
|
||||||
|
|
||||||
|
@ -303,29 +303,29 @@ public class WatchTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static ScheduleRegistry registry(Schedule schedule) {
|
private static ScheduleRegistry registry(Schedule schedule) {
|
||||||
ImmutableMap.Builder<String, Schedule.Parser> parsers = ImmutableMap.builder();
|
Map<String, Schedule.Parser> parsers = new HashMap<>();
|
||||||
switch (schedule.type()) {
|
switch (schedule.type()) {
|
||||||
case CronSchedule.TYPE:
|
case CronSchedule.TYPE:
|
||||||
parsers.put(CronSchedule.TYPE, new CronSchedule.Parser());
|
parsers.put(CronSchedule.TYPE, new CronSchedule.Parser());
|
||||||
return new ScheduleRegistry(parsers.build());
|
return new ScheduleRegistry(parsers);
|
||||||
case HourlySchedule.TYPE:
|
case HourlySchedule.TYPE:
|
||||||
parsers.put(HourlySchedule.TYPE, new HourlySchedule.Parser());
|
parsers.put(HourlySchedule.TYPE, new HourlySchedule.Parser());
|
||||||
return new ScheduleRegistry(parsers.build());
|
return new ScheduleRegistry(parsers);
|
||||||
case DailySchedule.TYPE:
|
case DailySchedule.TYPE:
|
||||||
parsers.put(DailySchedule.TYPE, new DailySchedule.Parser());
|
parsers.put(DailySchedule.TYPE, new DailySchedule.Parser());
|
||||||
return new ScheduleRegistry(parsers.build());
|
return new ScheduleRegistry(parsers);
|
||||||
case WeeklySchedule.TYPE:
|
case WeeklySchedule.TYPE:
|
||||||
parsers.put(WeeklySchedule.TYPE, new WeeklySchedule.Parser());
|
parsers.put(WeeklySchedule.TYPE, new WeeklySchedule.Parser());
|
||||||
return new ScheduleRegistry(parsers.build());
|
return new ScheduleRegistry(parsers);
|
||||||
case MonthlySchedule.TYPE:
|
case MonthlySchedule.TYPE:
|
||||||
parsers.put(MonthlySchedule.TYPE, new MonthlySchedule.Parser());
|
parsers.put(MonthlySchedule.TYPE, new MonthlySchedule.Parser());
|
||||||
return new ScheduleRegistry(parsers.build());
|
return new ScheduleRegistry(parsers);
|
||||||
case YearlySchedule.TYPE:
|
case YearlySchedule.TYPE:
|
||||||
parsers.put(YearlySchedule.TYPE, new YearlySchedule.Parser());
|
parsers.put(YearlySchedule.TYPE, new YearlySchedule.Parser());
|
||||||
return new ScheduleRegistry(parsers.build());
|
return new ScheduleRegistry(parsers);
|
||||||
case IntervalSchedule.TYPE:
|
case IntervalSchedule.TYPE:
|
||||||
parsers.put(IntervalSchedule.TYPE, new IntervalSchedule.Parser());
|
parsers.put(IntervalSchedule.TYPE, new IntervalSchedule.Parser());
|
||||||
return new ScheduleRegistry(parsers.build());
|
return new ScheduleRegistry(parsers);
|
||||||
default:
|
default:
|
||||||
throw new IllegalArgumentException("unknown schedule [" + schedule + "]");
|
throw new IllegalArgumentException("unknown schedule [" + schedule + "]");
|
||||||
}
|
}
|
||||||
|
@ -338,20 +338,20 @@ public class WatchTests extends ESTestCase {
|
||||||
SearchInput searchInput = searchInput(WatcherTestUtils.newInputSearchRequest("idx")).build();
|
SearchInput searchInput = searchInput(WatcherTestUtils.newInputSearchRequest("idx")).build();
|
||||||
return new ExecutableSearchInput(searchInput, logger, client, null);
|
return new ExecutableSearchInput(searchInput, logger, client, null);
|
||||||
default:
|
default:
|
||||||
SimpleInput simpleInput = InputBuilders.simpleInput(ImmutableMap.<String, Object>builder().put("_key", "_val")).build();
|
SimpleInput simpleInput = InputBuilders.simpleInput(singletonMap("_key", "_val")).build();
|
||||||
return new ExecutableSimpleInput(simpleInput, logger);
|
return new ExecutableSimpleInput(simpleInput, logger);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private InputRegistry registry(ExecutableInput input) {
|
private InputRegistry registry(ExecutableInput input) {
|
||||||
ImmutableMap.Builder<String, InputFactory> parsers = ImmutableMap.builder();
|
Map<String, InputFactory> parsers = new HashMap<>();
|
||||||
switch (input.type()) {
|
switch (input.type()) {
|
||||||
case SearchInput.TYPE:
|
case SearchInput.TYPE:
|
||||||
parsers.put(SearchInput.TYPE, new SearchInputFactory(settings, client));
|
parsers.put(SearchInput.TYPE, new SearchInputFactory(settings, client));
|
||||||
return new InputRegistry(parsers.build());
|
return new InputRegistry(parsers);
|
||||||
default:
|
default:
|
||||||
parsers.put(SimpleInput.TYPE, new SimpleInputFactory(settings));
|
parsers.put(SimpleInput.TYPE, new SimpleInputFactory(settings));
|
||||||
return new InputRegistry(parsers.build());
|
return new InputRegistry(parsers);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -370,20 +370,20 @@ public class WatchTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
private ConditionRegistry registry(ExecutableCondition condition) {
|
private ConditionRegistry registry(ExecutableCondition condition) {
|
||||||
ImmutableMap.Builder<String, ConditionFactory> parsers = ImmutableMap.builder();
|
Map<String, ConditionFactory> parsers = new HashMap<>();
|
||||||
switch (condition.type()) {
|
switch (condition.type()) {
|
||||||
case ScriptCondition.TYPE:
|
case ScriptCondition.TYPE:
|
||||||
parsers.put(ScriptCondition.TYPE, new ScriptConditionFactory(settings, scriptService));
|
parsers.put(ScriptCondition.TYPE, new ScriptConditionFactory(settings, scriptService));
|
||||||
return new ConditionRegistry(parsers.build());
|
return new ConditionRegistry(parsers);
|
||||||
case CompareCondition.TYPE:
|
case CompareCondition.TYPE:
|
||||||
parsers.put(CompareCondition.TYPE, new CompareConditionFactory(settings, SystemClock.INSTANCE));
|
parsers.put(CompareCondition.TYPE, new CompareConditionFactory(settings, SystemClock.INSTANCE));
|
||||||
return new ConditionRegistry(parsers.build());
|
return new ConditionRegistry(parsers);
|
||||||
case ArrayCompareCondition.TYPE:
|
case ArrayCompareCondition.TYPE:
|
||||||
parsers.put(ArrayCompareCondition.TYPE, new ArrayCompareConditionFactory(settings, SystemClock.INSTANCE));
|
parsers.put(ArrayCompareCondition.TYPE, new ArrayCompareConditionFactory(settings, SystemClock.INSTANCE));
|
||||||
return new ConditionRegistry(parsers.build());
|
return new ConditionRegistry(parsers);
|
||||||
default:
|
default:
|
||||||
parsers.put(AlwaysCondition.TYPE, new AlwaysConditionFactory(settings));
|
parsers.put(AlwaysCondition.TYPE, new AlwaysConditionFactory(settings));
|
||||||
return new ConditionRegistry(parsers.build());
|
return new ConditionRegistry(parsers);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -406,12 +406,12 @@ public class WatchTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
private TransformRegistry transformRegistry() {
|
private TransformRegistry transformRegistry() {
|
||||||
ImmutableMap.Builder<String, TransformFactory> factories = ImmutableMap.builder();
|
Map<String, TransformFactory> factories = new HashMap<>();
|
||||||
ChainTransformFactory parser = new ChainTransformFactory();
|
ChainTransformFactory parser = new ChainTransformFactory();
|
||||||
factories.put(ChainTransform.TYPE, parser);
|
factories.put(ChainTransform.TYPE, parser);
|
||||||
factories.put(ScriptTransform.TYPE, new ScriptTransformFactory(settings, scriptService));
|
factories.put(ScriptTransform.TYPE, new ScriptTransformFactory(settings, scriptService));
|
||||||
factories.put(SearchTransform.TYPE, new SearchTransformFactory(settings, client));
|
factories.put(SearchTransform.TYPE, new SearchTransformFactory(settings, client));
|
||||||
TransformRegistry registry = new TransformRegistry(factories.build());
|
TransformRegistry registry = new TransformRegistry(unmodifiableMap(factories));
|
||||||
parser.init(registry);
|
parser.init(registry);
|
||||||
return registry;
|
return registry;
|
||||||
}
|
}
|
||||||
|
@ -441,7 +441,7 @@ public class WatchTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
private ActionRegistry registry(ExecutableActions actions, TransformRegistry transformRegistry) {
|
private ActionRegistry registry(ExecutableActions actions, TransformRegistry transformRegistry) {
|
||||||
ImmutableMap.Builder<String, ActionFactory> parsers = ImmutableMap.builder();
|
Map<String, ActionFactory> parsers = new HashMap<>();
|
||||||
for (ActionWrapper action : actions) {
|
for (ActionWrapper action : actions) {
|
||||||
switch (action.action().type()) {
|
switch (action.action().type()) {
|
||||||
case EmailAction.TYPE:
|
case EmailAction.TYPE:
|
||||||
|
@ -455,7 +455,7 @@ public class WatchTests extends ESTestCase {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new ActionRegistry(parsers.build(), transformRegistry, SystemClock.INSTANCE, licenseService);
|
return new ActionRegistry(unmodifiableMap(parsers), transformRegistry, SystemClock.INSTANCE, licenseService);
|
||||||
}
|
}
|
||||||
|
|
||||||
private ActionThrottler randomThrottler() {
|
private ActionThrottler randomThrottler() {
|
||||||
|
|
Loading…
Reference in New Issue