/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER .
*
* This code is free software ; you can redistribute it and / or modify it
* under the terms of the GNU General Public License version 2 only , as
* published by the Free Software Foundation .
*
* This code is distributed in the hope that it will be useful , but WITHOUT
* ANY WARRANTY ; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE . See the GNU General Public License
* version 2 for more details ( a copy is included in the LICENSE file that
* accompanied this code ) .
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work ; if not , write to the Free Software Foundation ,
* Inc . , 51 Franklin St , Fifth Floor , Boston , MA 02110 - 1301 USA .
*
* Please contact Oracle , 500 Oracle Parkway , Redwood Shores , CA 94065 USA
* or visit www . oracle . com if you need additional information or have any
* questions .
*/
/*
* This file is available under and governed by the GNU General Public
* License version 2 only , as published by the Free Software Foundation .
* However , the following notice accompanied the original version of this
* file :
*
* Written by Doug Lea and Martin Buchholz with assistance from
* members of JCP JSR - 166 Expert Group and released to the public
* domain , as explained at
* http : //creativecommons.org/publicdomain/zero/1.0/
*/
import static java.util.concurrent.TimeUnit.DAYS;
import static java.util.concurrent.TimeUnit.HOURS;
import static java.util.concurrent.TimeUnit.MICROSECONDS;
import static java.util.concurrent.TimeUnit.MILLISECONDS;
import static java.util.concurrent.TimeUnit.MINUTES;
import static java.util.concurrent.TimeUnit.NANOSECONDS;
import static java.util.concurrent.TimeUnit.SECONDS;
import java.time.Duration;
import java.time.temporal.ChronoUnit;
import java.util.Arrays;
import java.util.concurrent.ThreadLocalRandom;
import java.util.concurrent.TimeUnit;
import java.util.stream.LongStream;
import junit.framework.Test;
import junit.framework.TestSuite;
public class TimeUnit8Test extends JSR166TestCase {
public static void main(String[] args) {
main(suite(), args);
}
public static Test suite() {
return new TestSuite(TimeUnit8Test.class );
}
/**
* tests for toChronoUnit .
*/
public void testToChronoUnit() throws Exception {
assertSame(ChronoUnit.NANOS, NANOSECONDS.toChronoUnit());
assertSame(ChronoUnit.MICROS, MICROSECONDS.toChronoUnit());
assertSame(ChronoUnit.MILLIS, MILLISECONDS.toChronoUnit());
assertSame(ChronoUnit.SECONDS, SECONDS.toChronoUnit());
assertSame(ChronoUnit.MINUTES, MINUTES.toChronoUnit());
assertSame(ChronoUnit.HOURS, HOURS.toChronoUnit());
assertSame(ChronoUnit.DAYS, DAYS.toChronoUnit());
// Every TimeUnit has a defined ChronoUnit equivalent
for (TimeUnit x : TimeUnit.values())
assertSame(x, TimeUnit.of(x.toChronoUnit()));
}
/**
* tests for TimeUnit . of ( ChronoUnit ) .
*/
public void testTimeUnitOf() throws Exception {
assertSame(NANOSECONDS, TimeUnit.of(ChronoUnit.NANOS));
assertSame(MICROSECONDS, TimeUnit.of(ChronoUnit.MICROS));
assertSame(MILLISECONDS, TimeUnit.of(ChronoUnit.MILLIS));
assertSame(SECONDS, TimeUnit.of(ChronoUnit.SECONDS));
assertSame(MINUTES, TimeUnit.of(ChronoUnit.MINUTES));
assertSame(HOURS, TimeUnit.of(ChronoUnit.HOURS));
assertSame(DAYS, TimeUnit.of(ChronoUnit.DAYS));
assertThrows(NullPointerException.class ,
() -> TimeUnit.of((ChronoUnit)null ));
// ChronoUnits either round trip to their TimeUnit
// equivalents, or throw IllegalArgumentException.
for (ChronoUnit cu : ChronoUnit.values()) {
final TimeUnit tu;
try {
tu = TimeUnit.of(cu);
} catch (IllegalArgumentException acceptable) {
continue ;
}
assertSame(cu, tu.toChronoUnit());
}
}
/**
* convert ( Duration ) roundtrips with Duration . ofXXXX and Duration . of ( long , ChronoUnit )
*/
public void testConvertDuration_roundtripDurationOf() {
long n = ThreadLocalRandom.current().nextLong();
assertEquals(n, NANOSECONDS.convert(Duration.ofNanos(n)));
assertEquals(n, NANOSECONDS.convert(Duration.of(n, ChronoUnit.NANOS)));
assertEquals(n, MILLISECONDS.convert(Duration.ofMillis(n)));
assertEquals(n, MILLISECONDS.convert(Duration.of(n, ChronoUnit.MILLIS)));
assertEquals(n, SECONDS.convert(Duration.ofSeconds(n)));
assertEquals(n, SECONDS.convert(Duration.of(n, ChronoUnit.SECONDS)));
n /= 60 ;
assertEquals(n, MINUTES.convert(Duration.ofMinutes(n)));
assertEquals(n, MINUTES.convert(Duration.of(n, ChronoUnit.MINUTES)));
n /= 60 ;
assertEquals(n, HOURS.convert(Duration.ofHours(n)));
assertEquals(n, HOURS.convert(Duration.of(n, ChronoUnit.HOURS)));
n /= 24 ;
assertEquals(n, DAYS.convert(Duration.ofDays(n)));
assertEquals(n, DAYS.convert(Duration.of(n, ChronoUnit.DAYS)));
}
/**
* convert ( Duration . ofNanos ( n ) ) agrees with convert ( n , NANOSECONDS )
*/
public void testConvertDuration_roundtripDurationOfNanos() {
// Test values near unit transitions and near overflow.
LongStream.concat(
Arrays.stream(TimeUnit.values()).mapToLong(u -> u.toNanos(1 )),
LongStream.of(Long .MAX_VALUE, Long .MIN_VALUE))
.flatMap(n -> LongStream.of(n, n + 1 , n - 1 ))
.flatMap(n -> LongStream.of(n, n + 1 _000 _000 _000 , n - 1 _000 _000 _000 ))
.flatMap(n -> LongStream.of(n, -n))
// .peek(System.err::println)
.forEach(n -> Arrays.stream(TimeUnit.values()).forEach(
u -> assertEquals(u.convert(n, NANOSECONDS),
u.convert(Duration.ofNanos(n)))));
}
/**
* convert ( Duration ) doesn ' t misbehave near Long . MAX_VALUE and Long . MIN_VALUE .
*/
public void testConvertDuration_nearOverflow() {
ChronoUnit NANOS = ChronoUnit.NANOS;
Duration maxDuration = Duration.ofSeconds(Long .MAX_VALUE, 999 _999 _999 );
Duration minDuration = Duration.ofSeconds(Long .MIN_VALUE, 0 );
for (TimeUnit u : TimeUnit.values()) {
ChronoUnit cu = u.toChronoUnit();
long r;
if (u.toNanos(1 ) > SECONDS.toNanos(1 )) {
r = u.toNanos(1 ) / SECONDS.toNanos(1 );
assertThrows(ArithmeticException.class ,
() -> Duration.of(Long .MAX_VALUE, cu),
() -> Duration.of(Long .MIN_VALUE, cu));
} else {
r = 1 ;
Duration max = Duration.of(Long .MAX_VALUE, cu);
Duration min = Duration.of(Long .MIN_VALUE, cu);
assertEquals(Long .MAX_VALUE, u.convert(max));
assertEquals(Long .MAX_VALUE - 1 , u.convert(max.minus(1 , NANOS)));
assertEquals(Long .MAX_VALUE - 1 , u.convert(max.minus(1 , cu)));
assertEquals(Long .MIN_VALUE, u.convert(min));
assertEquals(Long .MIN_VALUE + 1 , u.convert(min.plus(1 , NANOS)));
assertEquals(Long .MIN_VALUE + 1 , u.convert(min.plus(1 , cu)));
assertEquals(Long .MAX_VALUE, u.convert(max.plus(1 , NANOS)));
if (u != SECONDS) {
assertEquals(Long .MAX_VALUE, u.convert(max.plus(1 , cu)));
assertEquals(Long .MIN_VALUE, u.convert(min.minus(1 , NANOS)));
assertEquals(Long .MIN_VALUE, u.convert(min.minus(1 , cu)));
}
}
assertEquals(Long .MAX_VALUE / r, u.convert(maxDuration));
assertEquals(Long .MIN_VALUE / r, u.convert(minDuration));
}
}
}
Messung V0.5 in Prozent C=96 H=79 G=87
¤ Dauer der Verarbeitung: 0.5 Sekunden
¤
*© Formatika GbR, Deutschland