/* * The contents of this file are subject to the terms of the Common Development and * Distribution License (the License). You may not use this file except in compliance with the * License. * * You can obtain a copy of the License at legal/CDDLv1.0.txt. See the License for the * specific language governing permission and limitations under the License. * * When distributing Covered Software, include this CDDL Header Notice in each file and include * the License file at legal/CDDLv1.0.txt. If applicable, add the following below the CDDL * Header, with the fields enclosed by brackets [] replaced by your own identifying * information: "Portions copyright [year] [name of copyright owner]". * * Copyright 2016 ForgeRock AS. */ package org.forgerock.opendj.rest2ldap.schema; import static org.assertj.core.api.Assertions.assertThat; import org.forgerock.i18n.LocalizableMessageBuilder; import org.forgerock.opendj.ldap.ByteString; import org.forgerock.opendj.ldap.schema.Syntax; import org.forgerock.testng.ForgeRockTestCase; import org.testng.annotations.DataProvider; import org.testng.annotations.Test; @SuppressWarnings("javadoc") @Test public class JsonQuerySyntaxImplTest extends ForgeRockTestCase { private final Syntax syntax = JsonSchema.getJsonQuerySyntax(); @Test public void testGetName() throws Exception { assertThat(syntax.getName()).isEqualTo(JsonSchema.SYNTAX_JSON_QUERY_DESCRIPTION); } @Test public void testGetApproximateMatchingRule() throws Exception { assertThat(syntax.getApproximateMatchingRule()).isNull(); } @Test public void testGetEqualityMatchingRule() throws Exception { assertThat(syntax.getEqualityMatchingRule()).isNull(); } @Test public void testGetOrderingMatchingRule() throws Exception { assertThat(syntax.getOrderingMatchingRule()).isNull(); } @Test public void testGetSubstringMatchingRule() throws Exception { assertThat(syntax.getSubstringMatchingRule()).isNull(); } @Test public void testIsBEREncodingRequired() throws Exception { assertThat(syntax.isBEREncodingRequired()).isFalse(); } @Test public void testIsHumanReadable() throws Exception { assertThat(syntax.isHumanReadable()).isTrue(); } @DataProvider public static Object[][] validJsonQuery() { // There's no need to be exhaustive since the CREST unit tests should already provide sufficient coverage. // @formatter:off return new Object[][] { { "true" }, { "_id eq 123" }, { "_id eq \"bjensen\"" }, { "_id eq \"bjensen\" and /a/b/c eq true" }, }; // @formatter:on } @Test(dataProvider = "validJsonQuery") public void testValueIsAcceptableWithValidJson(String value) throws Exception { final LocalizableMessageBuilder localizableMessageBuilder = new LocalizableMessageBuilder(); final boolean valueIsAcceptable = syntax.valueIsAcceptable(ByteString.valueOfUtf8(value), localizableMessageBuilder); assertThat(valueIsAcceptable).isTrue(); assertThat(localizableMessageBuilder).isEmpty(); } @DataProvider public static Object[][] invalidJsonQuery() { // @formatter:off return new Object[][] { { "" }, { "bad value" }, { "/a%XXb eq 123" } // bad hex encoded char }; // @formatter:on } @Test(dataProvider = "invalidJsonQuery") public void testValueIsAcceptableWithInvalidValue(String value) throws Exception { final LocalizableMessageBuilder localizableMessageBuilder = new LocalizableMessageBuilder(); final boolean valueIsAcceptable = syntax.valueIsAcceptable(ByteString.valueOfUtf8(value), localizableMessageBuilder); assertThat(valueIsAcceptable).isFalse(); assertThat(localizableMessageBuilder).isNotEmpty(); } }