public inbox for mauve-patches@sourceware.org
 help / color / mirror / Atom feed
* 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).