Add extra test for julian dates

This commit is contained in:
Shahram Najm 2015-08-28 16:43:00 +01:00
parent ff50add703
commit a68262a9b3
3 changed files with 42 additions and 1 deletions

View File

@ -1,6 +1,11 @@
Test0...
1801 1 30 18:26:24 -> 2378891.268333
1801 1 30 18:26:24 -> 2378891.268333
Test1...
1957 10 4 19:26:24 -> 2436116.310000 1957 10 4 19:26:24 -> 2436116.310000
1957 10 4 19:26:24 -> 2436116.310000 1957 10 4 19:26:24 -> 2436116.310000
Test2...
+ 2000 1 1 12:0:0 -> 2451545.000000 + 2000 1 1 12:0:0 -> 2451545.000000
- 2000 1 1 12:0:0 -> 2451545.000000 - 2000 1 1 12:0:0 -> 2451545.000000
+ 20000101 -> 2451545 + 20000101 -> 2451545
@ -56,3 +61,5 @@
+ -47120001 -> 0 + -47120001 -> 0
- -47120001 -> 6 - -47120001 -> 6
Test3...
All OK

View File

@ -59,12 +59,41 @@ void TestDateTime(const long year, const long month, const long day, const long
} }
} }
void Test0()
{
long year, month, day, hour, min, sec;
double jd;
printf("Test0...\n");
/* Test a specific date */
year = 1801;
month = 1;
day = 30;
hour = 18;
min = 26;
sec = 24;
grib_datetime_to_julian(year, month, day, hour,min, sec, &jd);
assert( DBL_EQUAL(jd, 2378891.268333) );
printf("%ld %ld %ld %ld:%ld:%ld -> %f\n",year,month,day,hour,min,sec,jd);
grib_julian_to_datetime(jd, &year, &month, &day, &hour,&min, &sec);
assert( year == 1801 );
assert( month == 1 );
assert( day == 30 );
assert( hour == 18 );
assert( min == 26 );
assert( sec == 24 );
printf("%ld %ld %ld %ld:%ld:%ld -> %f\n",year,month,day,hour,min,sec,jd);
}
void Test1() void Test1()
{ {
long year, month, day, hour, min, sec; long year, month, day, hour, min, sec;
double jd; double jd;
/* Test a specific date */ /* Test a specific date */
printf("Test1...\n");
year = 1957; year = 1957;
month = 10; month = 10;
day = 4; day = 4;
@ -109,6 +138,7 @@ void Test2()
last=sizeof(jds)/sizeof(double); last=sizeof(jds)/sizeof(double);
printf("\n"); printf("\n");
printf("Test2...\n");
for (i=0;i<last;i++) { for (i=0;i<last;i++) {
jd=jds[i]; jd=jds[i];
grib_julian_to_datetime(jd,&year,&month,&day,&hour,&minute,&second); grib_julian_to_datetime(jd,&year,&month,&day,&hour,&minute,&second);
@ -133,6 +163,7 @@ void Test2()
void Test3() void Test3()
{ {
long iyear, imnth, iday, ihr, imin, isec; long iyear, imnth, iday, ihr, imin, isec;
printf("Test3...\n");
for (iyear=1950; iyear<=2015; iyear+=5) { for (iyear=1950; iyear<=2015; iyear+=5) {
for (imnth=1; imnth<=12; imnth+=1) { for (imnth=1; imnth<=12; imnth+=1) {
for (iday=1; iday<=28; iday+=1) { for (iday=1; iday<=28; iday+=1) {
@ -150,8 +181,10 @@ void Test3()
int main(int argc,char* argv[]) int main(int argc,char* argv[])
{ {
Test0();
Test1(); Test1();
Test2(); Test2();
Test3(); Test3();
printf("All OK\n");
return 0; return 0;
} }

View File

@ -14,4 +14,5 @@ ${test_dir}/julian > ${data_dir}/julian.out
diff ${data_dir}/julian.out ${data_dir}/julian.out.good diff ${data_dir}/julian.out ${data_dir}/julian.out.good
rm -f ${data_dir}/julian.out | true rm -f ${data_dir}/julian.out