11d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert/*
21d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * Copyright (C) 2011 The Guava Authors
31d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert *
41d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * Licensed under the Apache License, Version 2.0 (the "License");
51d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * you may not use this file except in compliance with the License.
61d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * You may obtain a copy of the License at
71d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert *
81d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * http://www.apache.org/licenses/LICENSE-2.0
91d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert *
101d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * Unless required by applicable law or agreed to in writing, software
111d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * distributed under the License is distributed on an "AS IS" BASIS,
121d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
131d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * See the License for the specific language governing permissions and
141d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * limitations under the License.
151d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert */
161d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
171d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertpackage com.google.common.collect;
181d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
191d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport static com.google.common.base.Preconditions.checkArgument;
201d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport static com.google.common.collect.DiscreteDomains.integers;
211d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
221d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport com.google.common.collect.testing.SampleElements;
231d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport com.google.common.collect.testing.SetTestSuiteBuilder;
241d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport com.google.common.collect.testing.TestSetGenerator;
251d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport com.google.common.collect.testing.features.CollectionFeature;
261d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport com.google.common.collect.testing.features.CollectionSize;
271d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport com.google.common.collect.testing.testers.SetHashCodeTester;
281d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
291d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport junit.framework.Test;
301d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport junit.framework.TestCase;
311d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport junit.framework.TestSuite;
321d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
331d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.Collections;
341d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.List;
351d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.Set;
361d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.SortedSet;
371d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.TreeSet;
381d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
391d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert/**
401d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * @author Gregory Kick
411d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert */
421d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertpublic class ContiguousSetNonGwtTest extends TestCase {
431d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert  public static class BuiltTests extends TestCase {
441d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    public static Test suite() {
451d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      TestSuite suite = new TestSuite();
461d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
471d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      suite.addTest(
481d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert          SetTestSuiteBuilder
491d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert              .using(
501d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                  new TestIntegerSetGenerator() {
511d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                    @Override
521d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                    protected Set<Integer> create(Integer[] elements) {
531d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                      // reject duplicates at creation, just so that I can use
541d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                      // that SetFeature below, which stops a test from running
551d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                      // that doesn't work. hack!
561d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                      SortedSet<Integer> set = new TreeSet<Integer>();
571d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                      Collections.addAll(set, elements);
581d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                      checkArgument(set.size() == elements.length);
591d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                      return Ranges.closed(set.first(), set.last()).asSet(integers());
601d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                    }
611d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                  })
621d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert              .withFeatures(
631d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                  CollectionSize.ONE,
641d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                  CollectionSize.SEVERAL,
651d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                  CollectionFeature.KNOWN_ORDER,
661d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                  CollectionFeature.ALLOWS_NULL_QUERIES,
671d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                  CollectionFeature.NON_STANDARD_TOSTRING,
681d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                  CollectionFeature.RESTRICTS_ELEMENTS,
691d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert                  CollectionFeature.REJECTS_DUPLICATES_AT_CREATION)
701d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert              .suppressing(SetHashCodeTester.getHashCodeMethods())
711d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert              .named("DiscreteRange.asSet, closed")
721d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert              .createTestSuite());
731d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
741d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      return suite;
751d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    }
761d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert  }
771d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
781d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert  abstract static class TestIntegerSetGenerator implements TestSetGenerator<Integer> {
791d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    @Override public SampleElements<Integer> samples() {
801d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      return new SampleElements<Integer>(1, 2, 3, 4, 5);
811d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    }
821d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
831d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    @Override public Set<Integer> create(Object... elements) {
841d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      Integer[] array = new Integer[elements.length];
851d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      int i = 0;
861d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      for (Object e : elements) {
871d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert        array[i++] = (Integer) e;
881d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      }
891d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      return create(array);
901d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    }
911d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
921d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    protected abstract Set<Integer> create(Integer[] elements);
931d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
941d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    @Override public Integer[] createArray(int length) {
951d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      return new Integer[length];
961d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    }
971d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
981d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    @Override public List<Integer> order(List<Integer> insertionOrder) {
991d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert      return Ordering.natural().sortedCopy(insertionOrder);
1001d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    }
1011d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert  }
1021d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert
1031d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert  public void testNothing() {
1041d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert    /*
1051d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert     * It's a warning if a TestCase subclass contains no tests, so we add one.
1061d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert     * Alternatively, we could stop extending TestCase, but I worry that someone
1071d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert     * will add a test in the future and not realize that it's being ignored.
1081d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert     */
1091d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert  }
1101d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert}
111