/* * 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 static org.forgerock.opendj.ldap.schema.Schema.getDefaultSchema; import static org.forgerock.opendj.rest2ldap.schema.JsonSchema.VALIDATION_POLICY; import static org.forgerock.opendj.rest2ldap.schema.JsonSchema.ValidationPolicy.LENIENT; import static org.forgerock.opendj.rest2ldap.schema.JsonSchema.addJsonSyntaxesAndMatchingRulesToSchema; import org.forgerock.i18n.LocalizableMessageBuilder; import org.forgerock.opendj.ldap.ByteString; import org.forgerock.opendj.ldap.schema.SchemaBuilder; 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 JsonSyntaxImplTest extends ForgeRockTestCase { private final Syntax syntax = addJsonSyntaxesAndMatchingRulesToSchema(new SchemaBuilder(getDefaultSchema())) .setOption(VALIDATION_POLICY, LENIENT) .toSchema() .getSyntax(JsonSchema.SYNTAX_JSON_OID); @Test public void testGetName() throws Exception { assertThat(syntax.getName()).isEqualTo(JsonSchema.SYNTAX_JSON_DESCRIPTION); } @Test public void testGetApproximateMatchingRule() throws Exception { assertThat(syntax.getApproximateMatchingRule()).isNull(); } @Test public void testGetEqualityMatchingRule() throws Exception { assertThat(syntax.getEqualityMatchingRule().getOID()).isEqualTo(JsonSchema.EMR_CASE_IGNORE_JSON_QUERY_OID); } @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[][] validJson() { return JsonQueryEqualityMatchingRuleImplTest.validJson(); } @DataProvider public static Object[][] invalidJson() { return JsonQueryEqualityMatchingRuleImplTest.invalidJson(); } @Test(dataProvider = "validJson") public void testValueIsAcceptableWithValidJson(String value, String normalizedValue) throws Exception { final LocalizableMessageBuilder localizableMessageBuilder = new LocalizableMessageBuilder(); final boolean valueIsAcceptable = syntax.valueIsAcceptable(ByteString.valueOfUtf8(value), localizableMessageBuilder); assertThat(valueIsAcceptable).isTrue(); assertThat(localizableMessageBuilder).isEmpty(); } @Test(dataProvider = "invalidJson") public void testValueIsAcceptableWithInvalidJson(String value) throws Exception { final LocalizableMessageBuilder localizableMessageBuilder = new LocalizableMessageBuilder(); final boolean valueIsAcceptable = syntax.valueIsAcceptable(ByteString.valueOfUtf8(value), localizableMessageBuilder); assertThat(valueIsAcceptable).isFalse(); assertThat(localizableMessageBuilder).isNotEmpty(); } }