summaryrefslogtreecommitdiffstats
path: root/tests/test_dates.cc
blob: b329fb638b25f748ecd3eab69505827cae3efae2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# define BOOST_TEST_DYN_LINK
# define BOOST_TEST_MODULE TestDates
# include <boost/test/unit_test.hpp>
# include <gmime/gmime.h>
# include "utils/gmime/gmime-compat.h"

# include "test_common.hh"
# include "message_thread.hh"
# include "compose_message.hh"
# include "utils/date_utils.hh"

using Astroid::Message;
using Astroid::ComposeMessage;

BOOST_AUTO_TEST_SUITE(Dates)

  BOOST_AUTO_TEST_CASE(dates_read_test)
  {
    setup ();

    {
      Message m ("tests/mail/test_mail/date1.eml");

      LOG (warn) << "date1:";
      LOG (test) << "pretty_date: " << m.pretty_date ();
      LOG (test) << "pretty_verbose_date: " << m.pretty_verbose_date ();
      LOG (test) << "pretty_verbose_date (true): " << m.pretty_verbose_date (true);
    }

    {
      Message m ("tests/mail/test_mail/date2.eml");

      LOG (warn) << "date2:";
      LOG (test) << "pretty_date: " << m.pretty_date ();
      LOG (test) << "pretty_verbose_date: " << m.pretty_verbose_date ();
      LOG (test) << "pretty_verbose_date (true): " << m.pretty_verbose_date (true);
    }

    teardown ();
  }


  BOOST_AUTO_TEST_CASE(dates_test_dates)
  {
    setup ();
    /* setlocale (LC_ALL, "C"); */

    std::vector<std::pair<ustring,ustring>> dates =
    {
      std::make_pair ("Tue, 19 Aug 2014 16:11:44 +0200", "Tue, 19 Aug 2014 16:11:44 +0200"),
      std::make_pair ("Mon, 9 May 2016 13:26:57 +0000",  "Mon, 09 May 2016 13:26:57 +0000"),
      std::make_pair ("Thu, 1 Sep 2016 14:32:16 +0000",  "Thu, 01 Sep 2016 14:32:16 +0000"),
    };


    Message a ("tests/mail/test_mail/date1.eml");

    for (auto d : dates) {
      LOG (warn) << "date: testing: " << d.first;

      GMimeMessage * m = a.message;
      g_object_ref (m);

# if (GMIME_MAJOR_VERSION < 3)
      g_mime_message_set_date_as_string (m, d.first.c_str ());
# else
      GDateTime * dt = g_mime_utils_header_decode_date (d.first.c_str ());
      g_mime_message_set_date (m, dt);
# endif

      Message b (m);

      LOG (test) << "date: " << b.date ();
      LOG (test) << "date, asctime: " << b.date_asctime ();
      LOG (test) << "pretty_date: " << b.pretty_date ();
      LOG (test) << "pretty_verbose_date: " << b.pretty_verbose_date ();
      LOG (test) << "pretty_verbose_date (true): " << b.pretty_verbose_date (true);

      BOOST_CHECK (b.date () == d.second);
    }


    LOG (test) << "Testing now date..";
    /* test compose message date setting */
    GMimeMessage * m = a.message;
    g_object_ref (m);

    /* hopefully these happen within the same second.. */
    GDateTime * now = g_date_time_new_now_local ();
    g_mime_message_set_date_now (m);

    Message b (m);
    LOG (test) << "date: " << b.date ();
    LOG (test) << "date, asctime: " << b.date_asctime ();
    LOG (test) << "pretty_date: " << b.pretty_date ();
    LOG (test) << "pretty_verbose_date: " << b.pretty_verbose_date ();
    LOG (test) << "pretty_verbose_date (true): " << b.pretty_verbose_date (true);

    const char * datefmt = "%a, %d %b %Y %T %z";
    setlocale (LC_ALL, "C");
    gchar * dt = g_date_time_format (now, datefmt);
    setlocale (LC_ALL, "");
    LOG (test) << "formatted date: " << dt;
    BOOST_CHECK (dt == b.date ());

    teardown ();
  }


BOOST_AUTO_TEST_SUITE_END()