use of au.gov.asd.tac.constellation.views.find.advanced.AdvancedFindPlugin in project constellation by constellation-app.
the class FindTopComponent method performSearch.
/**
* Gathers the state from the graph, and executes the
* <code>AdvancedQueryPlugin</code>, passing it the rules from the state.
* <p>
* (Where each <code>FindCriteriaPanel</code> represents an individual
* rule.)
*/
@SuppressWarnings("unchecked")
private void performSearch() {
final Graph graph = graphNode.getGraph();
final FindState state = saveStateToGraph();
final AdvancedFindPlugin queryPlugin = new AdvancedFindPlugin(type, state.getRules(), !state.isAny());
final Future<?> future = PluginExecution.withPlugin(queryPlugin).interactively(true).executeLater(graph);
// Wait for the search to find its results:
try {
future.get();
} catch (final InterruptedException ex) {
LOGGER.log(Level.SEVERE, "Thread was interrupted", ex);
Thread.currentThread().interrupt();
} catch (final ExecutionException ex) {
LOGGER.log(Level.SEVERE, ex.getLocalizedMessage(), ex);
}
final List<FindResult> results = queryPlugin.getResults();
final SelectFindResultsPlugin selectPlugin = new SelectFindResultsPlugin(results, state.isHeld());
PluginExecution.withPlugin(selectPlugin).interactively(true).executeLater(graph);
}
use of au.gov.asd.tac.constellation.views.find.advanced.AdvancedFindPlugin in project constellation by constellation-app.
the class FindNGTest method findBooleanValuesTest.
@Test
public void findBooleanValuesTest() throws InterruptedException, PluginException {
ArrayList<FindRule> rules = new ArrayList<>();
ReadableGraph rg = graph.getReadableGraph();
try {
// setup find criteria / rules
HashMap<String, Object> values = new HashMap<>();
values.put("boolean_content", true);
FindRule rule1 = new FindRule(FindTypeOperators.Type.BOOLEAN, new GraphAttribute(rg, vSelAttr), FindTypeOperators.Operator.IS, values);
rules.add(rule1);
// perform find search
// need to create temporary GraphNode and skip the RemoteInit portion of the initialisation
GraphNode aGraphNode = new GraphNode(graph, null, new TopComponent(), null);
final AdvancedFindPlugin queryPlugin = new AdvancedFindPlugin(GraphElementType.VERTEX, rules, false);
PluginExecution.withPlugin(queryPlugin).executeNow(graph);
final List<FindResult> results = queryPlugin.getResults();
// validate results
assertEquals("result size", 3, results.size());
assertTrue("node 'name2' found", nodeFound(rg, "name2", results));
assertTrue("node 'name4' found", nodeFound(rg, "name4", results));
assertTrue("node 'name6' found", nodeFound(rg, "name6", results));
} finally {
rg.release();
}
}
use of au.gov.asd.tac.constellation.views.find.advanced.AdvancedFindPlugin in project constellation by constellation-app.
the class FindNGTest method findSingleNodeCaseSensitiveFindTest.
@Test
public void findSingleNodeCaseSensitiveFindTest() throws InterruptedException, PluginException {
ArrayList<FindRule> rules = new ArrayList<>();
ReadableGraph rg = graph.getReadableGraph();
try {
// setup find criteria / rules
HashMap<String, Object> values = new HashMap<>();
values.put("string_content", "name1");
values.put("string_case_sensitive", true);
values.put("string_use_list", false);
FindRule rule1 = new FindRule(FindTypeOperators.Type.STRING, new GraphAttribute(rg, rg.getAttribute(GraphElementType.VERTEX, vNameAttr)), FindTypeOperators.Operator.IS, values);
rules.add(rule1);
// perform find search
// need to create temporary GraphNode and skip the RemoteInit portion of the initialisation
GraphNode gn = new GraphNode(graph, null, new TopComponent(), null);
final AdvancedFindPlugin queryPlugin = new AdvancedFindPlugin(GraphElementType.VERTEX, rules, false);
PluginExecution.withPlugin(queryPlugin).executeNow(graph);
final List<FindResult> results = queryPlugin.getResults();
// validate results
assertEquals("result size", 1, results.size());
assertTrue("node 'name1' found", nodeFound(rg, "name1", results));
} finally {
rg.release();
}
}
use of au.gov.asd.tac.constellation.views.find.advanced.AdvancedFindPlugin in project constellation by constellation-app.
the class FindNGTest method findFloatValuesTest.
@Test
public void findFloatValuesTest() throws InterruptedException, PluginException {
ArrayList<FindRule> rules = new ArrayList<>();
ReadableGraph rg = graph.getReadableGraph();
try {
// setup find criteria / rules
HashMap<String, Object> values = new HashMap<>();
values.put("float_first_item", 5.1f);
FindRule rule1 = new FindRule(FindTypeOperators.Type.FLOAT, new GraphAttribute(rg, attrX), FindTypeOperators.Operator.GREATER_THAN, values);
rules.add(rule1);
// perform find search
// need to create temporary GraphNode and skip the RemoteInit portion of the initialisation
GraphNode aGraphNode = new GraphNode(graph, null, new TopComponent(), null);
final AdvancedFindPlugin queryPlugin = new AdvancedFindPlugin(GraphElementType.VERTEX, rules, false);
PluginExecution.withPlugin(queryPlugin).executeNow(graph);
final List<FindResult> results = queryPlugin.getResults();
// validate results
assertEquals("result size", 2, results.size());
assertTrue("node 'name6' found", nodeFound(rg, "name6", results));
assertTrue("node 'name7' found", nodeFound(rg, "name7", results));
} finally {
rg.release();
}
}
use of au.gov.asd.tac.constellation.views.find.advanced.AdvancedFindPlugin in project constellation by constellation-app.
the class FindNGTest method findSingleNodeCaseSensitiveNoFindTest.
@Test
public void findSingleNodeCaseSensitiveNoFindTest() throws InterruptedException, PluginException {
ArrayList<FindRule> rules = new ArrayList<>();
ReadableGraph rg = graph.getReadableGraph();
try {
// setup find criteria / rules
HashMap<String, Object> values = new HashMap<>();
values.put("string_content", "Name1");
values.put("string_case_sensitive", true);
values.put("string_use_list", false);
FindRule rule1 = new FindRule(FindTypeOperators.Type.STRING, new GraphAttribute(rg, rg.getAttribute(GraphElementType.VERTEX, vNameAttr)), FindTypeOperators.Operator.IS, values);
rules.add(rule1);
// perform find search
// need to create temporary GraphNode and skip the RemoteInit portion of the initialisation
GraphNode aGraphNode = new GraphNode(graph, null, new TopComponent(), null);
final AdvancedFindPlugin queryPlugin = new AdvancedFindPlugin(GraphElementType.VERTEX, rules, false);
PluginExecution.withPlugin(queryPlugin).executeNow(graph);
final List<FindResult> results = queryPlugin.getResults();
// validate results
assertEquals("result size", 0, results.size());
} finally {
rg.release();
}
}
Aggregations