/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at * trunk/opends/resource/legal-notices/OpenDS.LICENSE * or https://OpenDS.dev.java.net/OpenDS.LICENSE. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at * trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable, * add the following below this CDDL HEADER, with the fields enclosed * by brackets "[]" replaced with your own identifying information: * Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END * * * Copyright 2006-2008 Sun Microsystems, Inc. */ package org.opends.server.types; import java.util.LinkedList; import java.util.List; import org.opends.server.TestCaseUtils; import org.testng.Assert; import org.testng.annotations.BeforeClass; import org.testng.annotations.DataProvider; import org.testng.annotations.Test; /** * This class defines a set of tests for the * org.opends.server.core.Attributes class. * <p> * Note that the <code>empty</code> and <code>create</code> methods * are all tested in the {@link AttributeBuilderTest} suit. */ public class AttributesTest extends TypesTestCase { /** * Merge attribute data provider. * * @return The array of merge attributes. */ @DataProvider(name = "mergeAttributes") public Object[][] mergeAttributes() { // Test testCase #, Attribute a1, Attribute a2, Attribute e, // Attribute d return new Object[][] { { 1, Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "one", "two", "three") }, { 2, Attributes.empty("cn"), Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "one", "two", "three"), Attributes.empty("cn") }, { 3, Attributes.create("cn", "one", "two", "three"), Attributes.empty("cn"), Attributes.create("cn", "one", "two", "three"), Attributes.empty("cn") }, { 4, Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "two", "three", "four"), Attributes.create("cn", "one", "two", "three", "four"), Attributes.create("cn", "two", "three") }, { 5, Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "four", "five", "six"), Attributes.create("cn", "one", "two", "three", "four", "five", "six"), Attributes.empty("cn") }, }; } /** * Set up the environment for performing the tests in this suite. * * @throws Exception * If the environment could not be set up. */ @BeforeClass public void setUp() throws Exception { // This test suite depends on having the schema available, so // we'll start the server. TestCaseUtils.startServer(); } /** * Subtract attribute data provider. * * @return The array of subtract attributes. */ @DataProvider(name = "subtractAttributes") public Object[][] subtractAttributes() { // Test testCase #, Attribute a1, Attribute a2, Attribute e, // Attribute m return new Object[][] { { 1, Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "one", "two", "three"), Attributes.empty("cn"), Attributes.empty("cn") }, { 2, Attributes.empty("cn"), Attributes.create("cn", "one", "two", "three"), Attributes.empty("cn"), Attributes.create("cn", "one", "two", "three") }, { 3, Attributes.create("cn", "one", "two", "three"), Attributes.empty("cn"), Attributes.create("cn", "one", "two", "three"), Attributes.empty("cn") }, { 4, Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "two", "three", "four"), Attributes.create("cn", "one"), Attributes.create("cn", "four") }, { 5, Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "four", "five", "six"), Attributes.create("cn", "one", "two", "three"), Attributes.create("cn", "four", "five", "six") }, }; } /** * Tests {@link Attributes#merge(Attribute, Attribute)}. * * @param testCase * Test case ID. * @param a1 * The first attribute to merge. * @param a2 * The second attribute to merge. * @param e * The expected result of the merge. * @param d * The expected set of duplicate values. * @throws Exception * If an unexpected error occurs. */ @Test(dataProvider = "mergeAttributes") public void testMerge(int testCase, Attribute a1, Attribute a2, Attribute e, Attribute d) throws Exception { Attribute actual = Attributes.merge(a1, a2); Assert.assertEquals(actual, e); } /** * Tests * {@link Attributes#merge(Attribute, Attribute, java.util.Collection)} * . * * @param testCase * Test case ID. * @param a1 * The first attribute to merge. * @param a2 * The second attribute to merge. * @param e * The expected result of the merge. * @param d * The expected set of duplicate values. * @throws Exception * If an unexpected error occurs. */ @Test(dataProvider = "mergeAttributes") public void testMergeWithDuplicates(int testCase, Attribute a1, Attribute a2, Attribute e, Attribute d) throws Exception { List<AttributeValue> duplicates = new LinkedList<AttributeValue>(); Attribute actual = Attributes.merge(a1, a2, duplicates); Assert.assertEquals(actual, e); Assert.assertEquals(duplicates.size(), d.size()); Assert.assertTrue(d.containsAll(duplicates)); } /** * Tests {@link Attributes#subtract(Attribute, Attribute)}. * * @param testCase * Test case ID. * @param a1 * The first attribute. * @param a2 * The second attribute to be subtracted. * @param e * The expected result of the subtraction. * @param m * The expected set of missing values. * @throws Exception * If an unexpected error occurs. */ @Test(dataProvider = "subtractAttributes") public void testSubtract(int testCase, Attribute a1, Attribute a2, Attribute e, Attribute m) throws Exception { Attribute actual = Attributes.subtract(a1, a2); Assert.assertEquals(actual, e); } /** * Tests * {@link Attributes#subtract(Attribute, Attribute, java.util.Collection)} * . * * @param testCase * Test case ID. * @param a1 * The first attribute. * @param a2 * The second attribute to be subtracted. * @param e * The expected result of the subtraction. * @param m * The expected set of missing values. * @throws Exception * If an unexpected error occurs. */ @Test(dataProvider = "subtractAttributes") public void testSubtractWithMissingValues(int testCase, Attribute a1, Attribute a2, Attribute e, Attribute m) throws Exception { List<AttributeValue> missingValues = new LinkedList<AttributeValue>(); Attribute actual = Attributes.subtract(a1, a2, missingValues); Assert.assertEquals(actual, e); Assert.assertEquals(missingValues.size(), m.size()); Assert.assertTrue(m.containsAll(missingValues)); } }