Will do, I’ll send out a v6 this evening, thank you!

Andrew


On Wed, Aug 27, 2025 at 8:51 AM Daniel Kiper <daniel.ki...@oracle.com>
wrote:

> On Tue, Aug 26, 2025 at 09:11:10PM -0500, Andrew Hamilton wrote:
> > Add tests outside the date range possible with 32-bit time
> > calculation. Also add a few more nominal date/time test values
> > to the 32-bit "tests" array. Add min / max tests for years 0001
> > and 9999.
> >
> > Signed-off-by: Vladimir Serbinenko <phco...@gmail.com>
> > Signed-off-by: Andrew Hamilton <adham...@gmail.com>
> > ---
> >  tests/date_unit_test.c | 75 +++++++++++++++++++++++++++++++++++++-----
> >  1 file changed, 66 insertions(+), 9 deletions(-)
> >
> > diff --git a/tests/date_unit_test.c b/tests/date_unit_test.c
> > index 99774f199..d3bf5a712 100644
> > --- a/tests/date_unit_test.c
> > +++ b/tests/date_unit_test.c
> > @@ -25,12 +25,13 @@
> >  #include <grub/test.h>
> >
> >  static void
> > -date_test (grub_int32_t v)
> > +date_test (grub_int64_t v)
> >  {
> >    struct grub_datetime dt;
> >    time_t t = v;
> >    struct tm *g;
> >    int w;
> > +  grub_int64_t back = 0;
> >
> >    g = gmtime (&t);
> >
> > @@ -38,28 +39,56 @@ date_test (grub_int32_t v)
> >
> >    w = grub_get_weekday (&dt);
> >
> > -  grub_test_assert (g->tm_sec == dt.second, "time %d bad second: %d vs
> %d", v,
> > +  grub_datetime2unixtime (&dt, &back);
> > +
> > +  grub_test_assert (g->tm_sec == dt.second, "time %lld bad second: %d
> vs %d", (long long) v,
> >                   g->tm_sec, dt.second);
> > -  grub_test_assert (g->tm_min == dt.minute, "time %d bad minute: %d vs
> %d", v,
> > +  grub_test_assert (g->tm_min == dt.minute, "time %lld bad minute: %d
> vs %d", (long long) v,
> >                   g->tm_min, dt.minute);
> > -  grub_test_assert (g->tm_hour == dt.hour, "time %d bad hour: %d vs
> %d", v,
> > +  grub_test_assert (g->tm_hour == dt.hour, "time %lld bad hour: %d vs
> %d", (long long) v,
> >                   g->tm_hour, dt.hour);
> > -  grub_test_assert (g->tm_mday == dt.day, "time %d bad day: %d vs %d",
> v,
> > +  grub_test_assert (g->tm_mday == dt.day, "time %lld bad day: %d vs
> %d", (long long) v,
> >                   g->tm_mday, dt.day);
> > -  grub_test_assert (g->tm_mon + 1 == dt.month, "time %d bad month: %d
> vs %d", v,
> > +  grub_test_assert (g->tm_mon + 1 == dt.month, "time %lld bad month: %d
> vs %d",(long long) v,
> >                   g->tm_mon + 1, dt.month);
> >    grub_test_assert (g->tm_year + 1900 == dt.year,
> > -                 "time %d bad year: %d vs %d", v,
> > +                   "time %lld bad year: %d vs %d", (long long) v,
> >                   g->tm_year + 1900, dt.year);
> > -  grub_test_assert (g->tm_wday == w, "time %d bad week day: %d vs %d",
> v,
> > +  grub_test_assert (g->tm_wday == w, "time %lld bad week day: %d vs
> %d", (long long) v,
> >                   g->tm_wday, w);
> > +  grub_test_assert (back == v, "time %lld bad back transform: %lld",
> (long long) v,
> > +                   (long long) back);
> >  }
> >
> >  static void
> >  date_test_iter (void)
> >  {
> > -  grub_int32_t tests[] = { -1, 0, +1, -2133156255, GRUB_INT32_MIN,
> > +  /*
> > +   * Test several interesting UNIX timestamps in 32-bit time:
> > +   *   1.             -1: 1969-12-31 23:59:59 - Just before EPOCH
> > +   *   2.              0: 1970-01-01 00:00:00 - EPOCH
> > +   *   3.             +1: 1970-01-01 00:00:01 - Just after EPOCH
> > +   *   4.      978224552: 2000-12-31 01:02:32 - Leap year, prior to Feb
>
> s/prior/after/?
>
> > +   *   5.    -2133156255: 1902-05-28 16:35:45 - Nominal value
> > +   *   6.    -2110094321: 1903-02-19 14:41:19 - Nominal value
> > +   *   7. GRUB_INT32_MIN: 1901-12-13 20:45:52 - 32-bit Min value
> > +   *   8. GRUB_INT32_MAX: 2038-01-19 03:14:07 - 32-bit Max value
> > +   */
> > +  grub_int32_t tests[] = { -1, 0, +1, 978224552, -2133156255,
> -2110094321, GRUB_INT32_MIN,
> >                          GRUB_INT32_MAX };
>
> Otherwise LGTM...
>
> When you fix the issue above you can add my RB...
>
> Daniel
>
_______________________________________________
Grub-devel mailing list
Grub-devel@gnu.org
https://lists.gnu.org/mailman/listinfo/grub-devel

Reply via email to