/*
* Copyright ( c ) 2014 , Oracle and / or its affiliates . All rights reserved .
* 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 .
*/
package test.sql;
import java.sql.Date;
import java.time.Instant;
import java.time.LocalDate;
import static org.testng.Assert .*;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
import util.BaseTest;
public class DateTests extends BaseTest {
/*
* Validate an IllegalArgumentException is thrown for an invalid Date string
*/
@Test(dataProvider = "invalidDateValues" ,
expectedExceptions = IllegalArgumentException.class )
public void test(String d) throws Exception {
Date.valueOf(d);
}
/*
* Test that a date created from a date string is equal to the value
* returned from toString ( )
*/
@Test(dataProvider = "validDateValues" )
public void test00(String d, String expectedD) {
Date d1 = Date.valueOf(d);
Date d2 = Date.valueOf(expectedD);
assertTrue(d1.equals(d2) && d2.equals(d1)
&& d1.toString().equals(expectedD), "Error d1 != d2" );
}
/*
* Validate that a Date . after ( ) returns false when same date is compared
*/
@Test
public void test01() {
Date d = Date.valueOf("1961-08-30" );
assertFalse(d.after(d), "Error d.after(d) = true" );
}
/*
* Validate that a Date . after ( ) returns true when later date is compared to
* earlier date
*/
@Test
public void test2() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(System.currentTimeMillis());
assertTrue(d2.after(d), "Error d2.after(d) = false" );
}
/*
* Validate that a Date . after ( ) returns false when earlier date is compared
* to later date
*/
@Test
public void test3() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(d.getTime());
assertFalse(d.after(d2), "Error d.after(d2) = true" );
}
/*
* Validate that a Date . after ( ) returns false when date compared to another
* date created from the original date
*/
@Test
public void test4() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(d.getTime());
assertFalse(d.after(d2), "Error d.after(d2) = true" );
assertFalse(d2.after(d), "Error d2.after(d) = true" );
}
/*
* Validate that a Date . before ( ) returns false when same date is compared
*/
@Test
public void test5() {
Date d = Date.valueOf("1961-08-30" );
assertFalse(d.before(d), "Error d.before(d) = true" );
}
/*
* Validate that a Date . before ( ) returns true when earlier date is compared
* to later date
*/
@Test
public void test6() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(System.currentTimeMillis());
assertTrue(d.before(d2), "Error d.before(d2) = false" );
}
/*
* Validate that a Date . before ( ) returns false when later date is compared
* to earlier date
*/
@Test
public void test7() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(d.getTime());
assertFalse(d2.before(d), "Error d2.before(d) = true" );
}
/*
* Validate that a Date . before ( ) returns false when date compared to another
* date created from the original date
*/
@Test
public void test8() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(d.getTime());
assertFalse(d.before(d2), "Error d.before(d2) = true" );
assertFalse(d2.before(d), "Error d2.before(d) = true" );
}
/*
* Validate that a Date . compareTo returns 0 when both Date objects are the
* same
*/
@Test
public void test9() {
Date d = Date.valueOf("1961-08-30" );
assertTrue(d.compareTo(d) == 0 , "Error d.compareTo(d) !=0" );
}
/*
* Validate that a Date . compareTo returns 0 when both Date objects represent
* the same date
*/
@Test
public void test10() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(d.getTime());
assertTrue(d.compareTo(d2) == 0 , "Error d.compareTo(d2) !=0" );
}
/*
* Validate that a Date . compareTo returns - 1 when comparing a date to a
* later date
*/
@Test
public void test11() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(System.currentTimeMillis());
assertTrue(d.compareTo(d2) == -1 , "Error d.compareTo(d2) != -1" );
}
/*
* Validate that a Date . compareTo returns 1 when comparing a date to an
* earlier date
*/
@Test
public void test12() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(System.currentTimeMillis());
assertTrue(d2.compareTo(d) == 1 , "Error d.compareTo(d2) != 1" );
}
/*
* Validate that a Date made from a LocalDate are equal
*/
@Test
public void test13() {
Date d = Date.valueOf("1961-08-30" );
LocalDate ldt = d.toLocalDate();
Date d2 = Date.valueOf(ldt);
assertTrue(d.equals(d2), "Error d != d2" );
}
/*
* Validate that a Date LocalDate value , made from a LocalDate are equal
*/
@Test
public void test14() {
LocalDate ldt = LocalDate.now();
Date d = Date.valueOf(ldt);
assertTrue(ldt.equals(d.toLocalDate()),
"Error LocalDate values are not equal" );
}
/*
* Validate an NPE occurs when a null LocalDate is passed to valueOf
*/
@Test(expectedExceptions = NullPointerException.class )
public void test15() throws Exception {
LocalDate ld = null ;
Date.valueOf(ld);
}
/*
* Validate an UnsupportedOperationException occurs when toInstant ( ) is
* called
*/
@Test(expectedExceptions = UnsupportedOperationException.class )
public void test16() throws Exception {
Date d = Date.valueOf("1961-08-30" );
Instant instant = d.toInstant();
}
/*
* Validate that two Date objects are equal when one is created from the
* toString ( ) of the other
*/
@Test
public void test17() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = Date.valueOf(d.toString());
assertTrue(d.equals(d2) && d2.equals(d), "Error d != d2" );
}
/*
* Validate that two Date values one created using valueOf and another via a
* constructor are equal
*/
@Test
public void test18() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(61 , 7 , 30 );
assertTrue(d.equals(d2), "Error d != d2" );
}
/*
* Validate that two Date values one created using getTime ( ) of the other
* are equal
*/
@Test
public void test19() {
Date d = Date.valueOf("1961-08-30" );
Date d2 = new Date(d.getTime());
assertTrue(d.equals(d2), "Error d != d2" );
}
/*
* Validate that a Date value is equal to itself
*/
@Test
public void test20() {
Date d = Date.valueOf("1961-08-30" );
assertTrue(d.equals(d), "Error d != d" );
}
/*
* Validate an IllegalArgumentException is thrown for calling getHours
*/
@Test(expectedExceptions = IllegalArgumentException.class )
public void test21() throws Exception {
Date d = Date.valueOf("1961-08-30" );
d.getHours();
}
/*
* Validate an IllegalArgumentException is thrown for calling getMinutes
*/
@Test(expectedExceptions = IllegalArgumentException.class )
public void test22() throws Exception {
Date d = Date.valueOf("1961-08-30" );
d.getMinutes();
}
/*
* Validate an IllegalArgumentException is thrown for calling getSeconds
*/
@Test(expectedExceptions = IllegalArgumentException.class )
public void test23() throws Exception {
Date d = Date.valueOf("1961-08-30" );
d.getSeconds();
}
/*
* Validate an IllegalArgumentException is thrown for calling setHours
*/
@Test(expectedExceptions = IllegalArgumentException.class )
public void test24() throws Exception {
Date d = Date.valueOf("1961-08-30" );
d.setHours(8 );
}
/*
* Validate an IllegalArgumentException is thrown for calling setMinutes
*/
@Test(expectedExceptions = IllegalArgumentException.class )
public void test25() throws Exception {
Date d = Date.valueOf("1961-08-30" );
d.setMinutes(0 );
}
/*
* Validate an IllegalArgumentException is thrown for calling setSeconds
*/
@Test(expectedExceptions = IllegalArgumentException.class )
public void test26() throws Exception {
Date d = Date.valueOf("1961-08-30" );
d.setSeconds(0 );
}
/*
* DataProvider used to provide Date which are not valid and are used
* to validate that an IllegalArgumentException will be thrown from the
* valueOf method
*/
@DataProvider(name = "invalidDateValues" )
private Object[][] invalidDateValues() {
return new Object[][]{
{"20009-11-01" },
{"09-11-01" },
{"-11-01" },
{"2009-111-01" },
{"2009--01" },
{"2009-13-01" },
{"2009-11-011" },
{"2009-11-" },
{"2009-11-00" },
{"2009-11-33" },
{"--" },
{"" },
{null },
{"-" },
{"2009" },
{"2009-01" },
{"---" },
{"2009-13--1" },
{"1900-1-0" },
{"2009-01-01 10:50:01" },
{"1996-12-10 12:26:19.1" },
{"10:50:01" }
};
}
/*
* DataProvider used to provide Dates which are valid and are used
* to validate that an IllegalArgumentException will not be thrown from the
* valueOf method and the corect value from toString ( ) is returned
*/
@DataProvider(name = "validDateValues" )
private Object[][] validDateValues() {
return new Object[][]{
{"2009-08-30" , "2009-08-30" },
{"2009-01-8" , "2009-01-08" },
{"2009-1-01" , "2009-01-01" },
{"2009-1-1" , "2009-01-01" }
};
}
}
Messung V0.5 in Prozent C=94 H=84 G=88
¤ Dauer der Verarbeitung: 0.9 Sekunden
¤
*© Formatika GbR, Deutschland