* FYI: GregorianCalendar day of week in month checks
@ 2007-04-05 10:19 Gary Benson
2007-04-05 13:32 ` FYI: More " Gary Benson
0 siblings, 1 reply; 2+ messages in thread
From: Gary Benson @ 2007-04-05 10:19 UTC (permalink / raw)
To: mauve-patches
[-- Attachment #1: Type: text/plain, Size: 40 bytes --]
Hi all,
Here be dragons.
Cheers,
Gary
[-- Attachment #2: patch --]
[-- Type: text/plain, Size: 5229 bytes --]
Index: ChangeLog
===================================================================
RCS file: /cvs/mauve/mauve/ChangeLog,v
retrieving revision 1.2046
diff -u -r1.2046 ChangeLog
--- ChangeLog 3 Apr 2007 13:04:25 -0000 1.2046
+++ ChangeLog 5 Apr 2007 10:18:05 -0000
@@ -1,3 +1,10 @@
+2007-04-05 Gary Benson <gbenson@redhat.com>
+
+ * gnu/testlet/java/util/GregorianCalendar/first.java:
+ Remove "day one is in week one" checks.
+ * gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java:
+ New test.
+
2007-04-03 Gary Benson <gbenson@redhat.com>
* gnu/testlet/java/util/Calendar/dstOffset.java: New test.
Index: gnu/testlet/java/util/GregorianCalendar/first.java
===================================================================
RCS file: /cvs/mauve/mauve/gnu/testlet/java/util/GregorianCalendar/first.java,v
retrieving revision 1.2
diff -u -r1.2 first.java
--- gnu/testlet/java/util/GregorianCalendar/first.java 2 Sep 2003 17:36:24 -0000 1.2
+++ gnu/testlet/java/util/GregorianCalendar/first.java 5 Apr 2007 10:18:05 -0000
@@ -27,8 +27,7 @@
import java.util.*;
/**
- * Checks that the first day of the month is day one and that the
- * first week is week one.
+ * Checks that the first day of the month is day one.
*/
public class first implements Testlet
{
@@ -53,8 +52,6 @@
GregorianCalendar cal = new GregorianCalendar(year, month, 1);
harness.check(cal.get(Calendar.DAY_OF_MONTH), 1,
"day 1-" + month + "-" + year);
- harness.check(cal.get(Calendar.WEEK_OF_MONTH), 1,
- "week 1-" + month + "-" + year);
}
}
}
Index: gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java
===================================================================
RCS file: gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java
diff -N gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java 5 Apr 2007 10:18:05 -0000
@@ -0,0 +1,93 @@
+// Copyright (C) 2007 Red Hat, Inc.
+// Written by Gary Benson <gbenson@redhat.com>
+// Including some tests by Bryce McKinlay.
+
+// This file is part of Mauve.
+
+// Mauve is free software; you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation; either version 2, or (at your option)
+// any later version.
+
+// Mauve 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 for more details.
+
+// You should have received a copy of the GNU General Public License
+// along with Mauve; see the file COPYING. If not, write to
+// the Free Software Foundation, 59 Temple Place - Suite 330,
+// Boston, MA 02111-1307, USA.
+
+// Tags: JDK1.1
+
+package gnu.testlet.java.util.GregorianCalendar;
+
+import java.util.Calendar;
+import java.util.GregorianCalendar;
+
+import gnu.testlet.Testlet;
+import gnu.testlet.TestHarness;
+
+public class dayOfWeekInMonth implements Testlet
+{
+ public void test(TestHarness harness)
+ {
+ GregorianCalendar c = new GregorianCalendar();
+
+ // 31 day months whose first days are the specified weekdays
+ int testMonths[][] =
+ {{Calendar.JANUARY, 2007, Calendar.MONDAY},
+ {Calendar.MAY, 2007, Calendar.TUESDAY},
+ {Calendar.AUGUST, 2007, Calendar.WEDNESDAY},
+ {Calendar.MARCH, 2007, Calendar.THURSDAY},
+ {Calendar.DECEMBER, 2006, Calendar.FRIDAY},
+ {Calendar.DECEMBER, 2007, Calendar.SATURDAY},
+ {Calendar.JULY, 2007, Calendar.SUNDAY}};
+
+ for (int minimalDaysInFirstWeek = 1;
+ minimalDaysInFirstWeek <= 7; minimalDaysInFirstWeek++) {
+
+ c.setMinimalDaysInFirstWeek(minimalDaysInFirstWeek);
+
+ for (int firstDayOfWeek = Calendar.SUNDAY;
+ firstDayOfWeek <= Calendar.SATURDAY; firstDayOfWeek++) {
+
+ c.setFirstDayOfWeek(firstDayOfWeek);
+
+ for (int i = 0; i < testMonths.length; i++) {
+ int month = testMonths[i][0];
+ int year = testMonths[i][1];
+ int first = testMonths[i][2];
+
+ for (int day = 1; day <= 31; day++) {
+ c.set(year, month, day);
+ harness.check(c.get(Calendar.DAY_OF_WEEK_IN_MONTH) == (day+6) / 7);
+
+ int dayOfWeek = c.get(Calendar.DAY_OF_WEEK);
+ if (day == 1)
+ harness.check(dayOfWeek == first); // sanity
+
+ // which day of the week are we (0..6) relative to firstDayOfWeek
+ int relativeDayOfWeek = (7 + dayOfWeek - firstDayOfWeek) % 7;
+
+ // which day of the week is the first of this month?
+ // nb 35 is the smallest multiple of 7 that ensures that
+ // the left hand side of the modulo operator is positive.
+ int relativeDayOfFirst = (relativeDayOfWeek - day + 1 + 35) % 7;
+
+ // which week of the month is the first of this month in?
+ int weekOfFirst =
+ ((7 - relativeDayOfFirst) >= minimalDaysInFirstWeek) ? 1 : 0;
+
+ // which week of the month is this day in?
+ int weekOfMonth =
+ (day + relativeDayOfFirst - 1) / 7 + weekOfFirst;
+
+ harness.check(c.get(Calendar.WEEK_OF_MONTH) == weekOfMonth);
+ }
+ }
+ }
+ }
+ }
+}
^ permalink raw reply [flat|nested] 2+ messages in thread
* FYI: More GregorianCalendar day of week in month checks
2007-04-05 10:19 FYI: GregorianCalendar day of week in month checks Gary Benson
@ 2007-04-05 13:32 ` Gary Benson
0 siblings, 0 replies; 2+ messages in thread
From: Gary Benson @ 2007-04-05 13:32 UTC (permalink / raw)
To: mauve-patches
[-- Attachment #1: Type: text/plain, Size: 412 bytes --]
Hi again,
The tests in java.util.GregorianCalendar.dayOfWeekInMonth check that
DAY_OF_WEEK_IN_MONTH and WEEK_OF_MONTH are correct when you set dates
using YEAR + MONTH + DAY_OF_MONTH. This commit adds checks in the
opposite direction, ie that DAY_OF_MONTH is correct when you set dates
using YEAR + MONTH + DAY_OF_WEEK_IN_MONTH + DAY_OF_WEEK and using
YEAR + MONTH + WEEK_OF_MONTH + DAY_OF_WEEK.
Cheers,
Gary
[-- Attachment #2: patch --]
[-- Type: text/plain, Size: 3350 bytes --]
Index: ChangeLog
===================================================================
RCS file: /cvs/mauve/mauve/ChangeLog,v
retrieving revision 1.2047
diff -u -r1.2047 ChangeLog
--- ChangeLog 5 Apr 2007 10:18:35 -0000 1.2047
+++ ChangeLog 5 Apr 2007 13:27:14 -0000
@@ -1,3 +1,8 @@
+2007-04-05 Gary Benson <gbenson@redhat.com>
+
+ * gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java:
+ Test in the opposite direction too.
+
2007-04-05 Gary Benson <gbenson@redhat.com>
* gnu/testlet/java/util/GregorianCalendar/first.java:
Index: gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java
===================================================================
RCS file: /cvs/mauve/mauve/gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java,v
retrieving revision 1.1
diff -u -r1.1 dayOfWeekInMonth.java
--- gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java 5 Apr 2007 10:18:35 -0000 1.1
+++ gnu/testlet/java/util/GregorianCalendar/dayOfWeekInMonth.java 5 Apr 2007 13:27:14 -0000
@@ -34,6 +34,8 @@
public void test(TestHarness harness)
{
GregorianCalendar c = new GregorianCalendar();
+ GregorianCalendar d = new GregorianCalendar();
+ GregorianCalendar e = new GregorianCalendar();
// 31 day months whose first days are the specified weekdays
int testMonths[][] =
@@ -49,11 +51,15 @@
minimalDaysInFirstWeek <= 7; minimalDaysInFirstWeek++) {
c.setMinimalDaysInFirstWeek(minimalDaysInFirstWeek);
+ d.setMinimalDaysInFirstWeek(minimalDaysInFirstWeek);
+ e.setMinimalDaysInFirstWeek(minimalDaysInFirstWeek);
for (int firstDayOfWeek = Calendar.SUNDAY;
firstDayOfWeek <= Calendar.SATURDAY; firstDayOfWeek++) {
c.setFirstDayOfWeek(firstDayOfWeek);
+ d.setFirstDayOfWeek(firstDayOfWeek);
+ e.setFirstDayOfWeek(firstDayOfWeek);
for (int i = 0; i < testMonths.length; i++) {
int month = testMonths[i][0];
@@ -61,8 +67,14 @@
int first = testMonths[i][2];
for (int day = 1; day <= 31; day++) {
+ // First we set YEAR + MONTH + DAY_OF_MONTH and check we
+ // have DAY_OF_WEEK_IN_MONTH and WEEK_OF_MONTH correct.
+
c.set(year, month, day);
- harness.check(c.get(Calendar.DAY_OF_WEEK_IN_MONTH) == (day+6) / 7);
+ int dayOfWeekInMonth = (day + 6) / 7;
+
+ harness.check(
+ c.get(Calendar.DAY_OF_WEEK_IN_MONTH) == dayOfWeekInMonth);
int dayOfWeek = c.get(Calendar.DAY_OF_WEEK);
if (day == 1)
@@ -85,6 +97,26 @@
(day + relativeDayOfFirst - 1) / 7 + weekOfFirst;
harness.check(c.get(Calendar.WEEK_OF_MONTH) == weekOfMonth);
+
+ // Then we set YEAR + MONTH + DAY_OF_WEEK_IN_MONTH +
+ // DAY_OF_WEEK and check we have DAY_OF_MONTH correct.
+
+ d.clear();
+ d.set(Calendar.YEAR, year);
+ d.set(Calendar.MONTH, month);
+ d.set(Calendar.DAY_OF_WEEK_IN_MONTH, dayOfWeekInMonth);
+ d.set(Calendar.DAY_OF_WEEK, dayOfWeek);
+ harness.check(d.get(Calendar.DAY_OF_MONTH) == day);
+
+ // Finally we set YEAR + MONTH + WEEK_OF_MONTH + DAY_OF_WEEK
+ // and check we have DAY_OF_MONTH correct.
+
+ e.clear();
+ e.set(Calendar.YEAR, year);
+ e.set(Calendar.MONTH, month);
+ e.set(Calendar.WEEK_OF_MONTH, weekOfMonth);
+ e.set(Calendar.DAY_OF_WEEK, dayOfWeek);
+ harness.check(e.get(Calendar.DAY_OF_MONTH) == day);
}
}
}
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2007-04-05 13:32 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2007-04-05 10:19 FYI: GregorianCalendar day of week in month checks Gary Benson
2007-04-05 13:32 ` FYI: More " Gary Benson
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).