optionsName -> { if (!options.contains(optionsName)) { stagingOptionsManager.deleteOptions(optionsName); optionsName -> { if (!options.contains(optionsName)) { finalOptionsManager.deleteOptions(optionsName);
@Test public void testQueryOptionsManager() throws JAXBException, ResourceNotFoundException, ForbiddenUserException, FailedRequestException, ResourceNotResendableException { QueryOptionsManager mgr = Common.adminClient.newServerConfigManager().newQueryOptionsManager(); assertNotNull("Client could not create query options manager", mgr); mgr.writeOptions("testempty", new StringHandle("{\"options\":{}}").withFormat(Format.JSON)); String optionsResult = mgr.readOptions("testempty", new StringHandle()).get(); logger.debug("Empty options from server {}", optionsResult); assertTrue("Empty options result not empty",optionsResult.contains("options")); assertTrue("Empty options result not empty",optionsResult.contains("\"http://marklogic.com/appservices/search\"/>")); mgr.deleteOptions("testempty"); };
@Test public void testJSONOptions() throws JAXBException, ResourceNotFoundException, ForbiddenUserException, FailedRequestException, ResourceNotResendableException { QueryOptionsManager mgr = Common.adminClient.newServerConfigManager().newQueryOptionsManager(); assertNotNull("Client could not create query options manager", mgr); FileHandle jsonHandle = new FileHandle(new File("src/test/resources/json-config.json")); jsonHandle.setFormat(Format.JSON); mgr.writeOptions("jsonoptions", jsonHandle); JsonNode options = mgr.readOptions("jsonoptions", new JacksonHandle()).get(); assertEquals("JSON options came back incorrectly", options.findPath("constraint").get(0).get("name").textValue(), "decade"); StringHandle jsonStringHandle = new StringHandle(); jsonStringHandle.setFormat(Format.JSON); mgr.readOptions("jsonoptions", jsonStringHandle); assertTrue("JSON String from QueryManager must start with json options", jsonStringHandle.get().startsWith("{\"options\":")); mgr.deleteOptions("jsonoptions"); }; }
@AfterClass public static void afterClass() throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException { confMgr.newQueryOptionsManager().deleteOptions(optionsName); extensionMgr.deleteTransform(MLCP_TRANSFORM_ADAPTER); extensionMgr.deleteTransform(TransformExtensionsTest.XQUERY_NAME); extensionMgr.deleteTransform(TransformExtensionsTest.XSLT_NAME); libMgr.delete("/ext/RestTransformAdapter.xqy"); libMgr.delete("/ext/memory-operations.xqy"); libMgr.delete("/ext/node-operations.xqy"); }
@Test public void testValuesPaging() throws IOException, ParserConfigurationException, SAXException { String optionsName = makeValuesOptions(); QueryManager queryMgr = Common.client.newQueryManager(); queryMgr.setPageLength(2); ValuesDefinition vdef = queryMgr.newValuesDefinition("double", optionsName); ValuesHandle v = queryMgr.values(vdef, new ValuesHandle(), 2); CountedDistinctValue dv[] = v.getValues(); assertNotNull("There should be values", dv); assertEquals("There should be 2 values", 2, dv.length); assertEquals("The first value should be '1.2'", dv[0].get("xs:double", Double.class).toString(), "1.2"); assertEquals("The second value should be '2.2'", dv[1].get("xs:double", Double.class).toString(), "2.2"); Common.adminClient.newServerConfigManager().newQueryOptionsManager().deleteOptions(optionsName); }
assertEquals("The last tuple is '2.2 | 4'", "2.2 | 4", value); optionsMgr.deleteOptions("valuesoptions");
@Test public void testAggregates() throws IOException, ParserConfigurationException, SAXException, ResourceNotFoundException, ForbiddenUserException, FailedRequestException, ResourceNotResendableException { String optionsName = makeValuesOptions(); QueryManager queryMgr = Common.client.newQueryManager(); ValuesDefinition vdef = queryMgr.newValuesDefinition("double", optionsName); vdef.setAggregate("sum", "avg"); vdef.setName("double"); //ValuesListDefinition vldef = queryMgr.newValuesListDefinition("valuesoptions"); //ValuesListHandle vlh = queryMgr.valuesList(vldef, new ValuesListHandle()); ValuesHandle v = queryMgr.values(vdef, new ValuesHandle()); AggregateResult[] agg = v.getAggregates(); assertEquals("There should be 2 aggregates", 2, agg.length); double first = agg[0].get("xs:double", Double.class); assertTrue("Aggregate 1 should be between 11.4 and 12", 11.4 < first && first < 12.0); double second = agg[1].get("xs:double", Double.class); logger.debug("" + second); assertTrue("Aggregate 2 should be between 1.43 and 1.44", 1.43 < second && second < 1.44); Common.adminClient.newServerConfigManager().newQueryOptionsManager().deleteOptions(optionsName); }
@Test public void testAggregates() throws IOException, ParserConfigurationException, SAXException, ResourceNotFoundException, ForbiddenUserException, FailedRequestException, ResourceNotResendableException { QueryOptionsManager optionsMgr = Common.adminClient.newServerConfigManager().newQueryOptionsManager(); optionsMgr.writeOptions("valuesoptions2", new StringHandle(options)); logger.debug(options.toString()); QueryManager queryMgr = Common.client.newQueryManager(); ValuesDefinition vdef = queryMgr.newValuesDefinition("co", "valuesoptions2"); vdef.setAggregate("correlation", "covariance"); TuplesHandle t = queryMgr.tuples(vdef, new TuplesHandle()); AggregateResult[] agg = t.getAggregates(); assertEquals("Two aggregates are expected", 2, agg.length); double cov = t.getAggregate("covariance").get("xs:double", Double.class); assertTrue("The covariance is between 1.551 and 1.552", cov > 1.551 && cov < 1.552); Tuple[] tuples = t.getTuples(); assertEquals("Twelve tuples are expected", 12, tuples.length); assertEquals("The tuples are named 'co'", "co", t.getName()); ValuesMetrics metrics = t.getMetrics(); assertTrue("The values resolution time is >= 0", metrics.getValuesResolutionTime() >= 0); assertTrue("The aggregate resolution time is >= 0", metrics.getAggregateResolutionTime() >= 0); optionsMgr.deleteOptions("valuesoptions2"); }
@Test public void testCoVariances() throws IOException, ParserConfigurationException, SAXException, ResourceNotFoundException, ForbiddenUserException, FailedRequestException, ResourceNotResendableException { QueryOptionsManager optionsMgr = Common.adminClient.newServerConfigManager().newQueryOptionsManager(); optionsMgr.writeOptions("valuesoptions3", new StringHandle(options)); QueryManager queryMgr = Common.client.newQueryManager(); ValuesDefinition vdef = queryMgr.newValuesDefinition("co", "valuesoptions3"); TuplesHandle t = queryMgr.tuples(vdef, new TuplesHandle()); Tuple[] tuples = t.getTuples(); assertEquals("Twelve tuples are expected", 12, tuples.length); assertEquals("The tuples are named 'co'", "co", t.getName()); ValuesMetrics metrics = t.getMetrics(); assertTrue("The values resolution time is >= 0", metrics.getValuesResolutionTime() >= 0); // Restore after bug:18747 is fixed // assertEquals("The aggregate resolution time is -1 (absent)", metrics.getAggregateResolutionTime(), -1); optionsMgr.deleteOptions("valuesoptions3"); }
assertEquals("cuba.xml", summary.getUri()); optionsMgr.deleteOptions("geooptions");
@Test public void testValuesHandle() throws IOException, ParserConfigurationException, SAXException, ResourceNotFoundException, ForbiddenUserException, FailedRequestException, ResourceNotResendableException { QueryOptionsManager optionsMgr = Common.adminClient.newServerConfigManager().newQueryOptionsManager(); optionsMgr.writeOptions("valuesoptions", new StringHandle(options)); QueryManager queryMgr = Common.client.newQueryManager(); ValuesDefinition vdef = queryMgr.newValuesDefinition("co", "valuesoptions"); TuplesHandle t = queryMgr.tuples(vdef, new TuplesHandle()); Tuple[] tuples = t.getTuples(); assertEquals("Twelve tuples are expected", 12, tuples.length); assertEquals("The tuples are named 'co'", "co", t.getName()); TypedDistinctValue[] dv = tuples[0].getValues(); assertEquals("Two values per tuple expected", 2, dv.length); assertEquals("First is long", "xs:double", dv[0].getType()); assertEquals("Second is int", "xs:int", dv[1].getType()); assertEquals("Frequency is 1", 1, tuples[0].getCount()); assertEquals("First value", 1.1, (double) dv[0].get(Double.class), 0.01); assertEquals("Second value", (int) 1, (int) dv[1].get(Integer.class)); optionsMgr.deleteOptions("valuesoptions"); }
Common.adminClient.newServerConfigManager().newQueryOptionsManager().deleteOptions(optionsName);
@Test public void testNWayTuples() throws ResourceNotFoundException, ForbiddenUserException, FailedRequestException, ResourceNotResendableException { QueryOptionsManager optionsMgr = Common.adminClient.newServerConfigManager().newQueryOptionsManager(); optionsMgr.writeOptions("valuesoptions", new StringHandle(options)); QueryManager queryMgr = Common.client.newQueryManager(); ValuesDefinition vdef = queryMgr.newValuesDefinition("n-way", "valuesoptions"); TuplesHandle t = queryMgr.tuples(vdef, new TuplesHandle()); Tuple[] tuples = t.getTuples(); assertEquals("Four tuples are expected", 4, tuples.length); assertEquals("The tuples are named 'n-way'", "n-way", t.getName()); TypedDistinctValue[] dv = tuples[0].getValues(); assertEquals("Three values per tuple expected", 3, dv.length); assertEquals("First is long", "xs:double", dv[0].getType()); assertEquals("Second is int", "xs:int", dv[1].getType()); assertEquals("Third is string", "xs:string", dv[2].getType()); assertEquals("Frequency is 1", 1, tuples[0].getCount()); assertEquals("First value", 1.1, (double) dv[0].get(Double.class), 0.01); assertEquals("Second value", (int) 1, (int) dv[1].get(Integer.class)); assertEquals("Third value", "Alaska", (String) dv[2].get(String.class)); optionsMgr.deleteOptions("valuesoptions"); }
summaries = results.getMatchResults(); assertEquals(1, summaries.length); optionsMgr.deleteOptions("geodoubleoptions");