timewarrior/test/chart.t
Thomas Lauf 6d79ea4a6d Update copyright statements
Signed-off-by: Thomas Lauf <thomas.lauf@tngtech.com>
2023-09-18 12:33:17 +02:00

203 lines
9.2 KiB
Python
Executable file

#!/usr/bin/env python3
###############################################################################
#
# Copyright 2017 - 2019, Thomas Lauf, Paul Beckingham, Federico Hernandez.
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included
# in all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
#
# https://www.opensource.org/licenses/mit-license.php
#
###############################################################################
import os
import sys
import unittest
from datetime import datetime, timedelta
# Ensure python finds the local simpletap module
sys.path.append(os.path.dirname(os.path.abspath(__file__)))
from basetest import Timew, TestCase
class TestChart(TestCase):
def setUp(self):
"""Executed before each test in the class"""
self.t = Timew()
def test_empty(self):
"""Chart should print warning if no data in range"""
code, out, err = self.t("day")
self.assertIn("No filtered data found in the range", out)
def test_empty_with_exclusions(self):
"""Chart should print warning if no data in range and exclusions and time specified"""
self.t.config("exclusions.days.monday", "off")
self.t.config("exclusions.days.tuesday", "off")
self.t.config("exclusions.days.wednesday", "off")
self.t.config("exclusions.days.thursday", "off")
self.t.config("exclusions.days.friday", "off")
self.t.config("exclusions.days.saturday", "off")
self.t.config("exclusions.days.sunday", "off")
now = datetime.now()
three_hours_before = now - timedelta(hours=3)
code, out, err = self.t("day {:%H:%M:%S}".format(three_hours_before.time()))
self.assertIn("No filtered data found in the range", out)
def test_chart_day_with_invalid_config_for_lines(self):
"""Chart should report error on invalid value for 'reports.day.lines'"""
self.t("track for 1h")
code, out, err = self.t.runError("day rc.reports.day.lines=foobar")
self.assertIn("Invalid integer value for 'reports.day.lines': 'foobar'", err)
def test_chart_day_with_invalid_config_for_cell(self):
"""Chart should report error on invalid value for 'reports.day.cell'"""
self.t("track for 1h")
code, out, err = self.t.runError("day rc.reports.day.cell=foobar")
self.assertIn("Invalid integer value for 'reports.day.cell': 'foobar'", err)
def test_chart_week_with_invalid_config_for_lines(self):
"""Chart should report error on invalid value for 'reports.week.lines'"""
self.t("track for 1h")
code, out, err = self.t.runError("week rc.reports.week.lines=foobar")
self.assertIn("Invalid integer value for 'reports.week.lines': 'foobar'", err)
def test_chart_week_with_invalid_config_for_cell(self):
"""Chart should report error on invalid value for 'reports.week.cell'"""
self.t("track for 1h")
code, out, err = self.t.runError("week rc.reports.week.cell=foobar")
self.assertIn("Invalid integer value for 'reports.week.cell': 'foobar'", err)
def test_chart_month_with_invalid_config_for_lines(self):
"""Chart should report error on invalid value for 'reports.month.lines'"""
self.t("track for 1h")
code, out, err = self.t.runError("month rc.reports.month.lines=foobar")
self.assertIn("Invalid integer value for 'reports.month.lines': 'foobar'", err)
def test_chart_month_with_invalid_config_for_cell(self):
"""Chart should report error on invalid value for 'reports.month.cell'"""
self.t("track for 1h")
code, out, err = self.t.runError("month rc.reports.month.cell=foobar")
self.assertIn("Invalid integer value for 'reports.month.cell': 'foobar'", err)
def test_chart_day_with_less_than_one_minute_interval_at_day_start(self):
self.t("track 2016-01-15T00:00:00 - 2016-01-15T00:00:40 XOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXO")
code, out, err = self.t("day 2016-01-15 - 2016-01-16")
self.assertIn("""\
\nFri 15 XOXO 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 \
\n XOXO \
\n
Tracked 0:00:40
Available 23:59:20
Total 24:00:00
""", out)
def test_chart_day_with_less_than_one_minute_interval(self):
self.t(
"track 2016-01-15T02:00:00 - 2016-01-15T02:00:40 XOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXO")
code, out, err = self.t("day 2016-01-15 - 2016-01-16")
self.assertIn("""\
\nFri 15 0 1 XOXO 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 \
\n XOXO \
\n
Tracked 0:00:40
Available 23:59:20
Total 24:00:00
""", out)
def test_chart_day_with_less_than_one_hour_interval_at_day_start(self):
self.t(
"track 2016-01-15T00:00:00 - 2016-01-15T00:30:00 XOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXO")
code, out, err = self.t("day 2016-01-15 - 2016-01-16")
self.assertIn("""\
\nFri 15 XO 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 \
\n XO \
\n
Tracked 0:30:00
Available 23:30:00
Total 24:00:00
""", out)
def test_chart_day_with_less_than_one_hour_interval(self):
self.t(
"track 2016-01-15T02:00:00 - 2016-01-15T02:30:00 XOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXO")
code, out, err = self.t("day 2016-01-15 - 2016-01-16")
self.assertIn("""\
\nFri 15 0 1 XO 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 \
\n XO \
\n
Tracked 0:30:00
Available 23:30:00
Total 24:00:00
""", out)
def test_chart_day_with_interval_over_day_border(self):
self.t("track 2016-01-15T23:00:00 - 2016-01-16T01:00:00 XOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXO")
code, out, err = self.t("day 2016-01-15 - 2016-01-17")
self.assertIn("""\
\nFri 15 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 XOXOX\
\n OXOXO\
\nSat 16 XOXOX1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 \
\n OXOXO \
\n
Tracked 2:00:00
Available 46:00:00
Total 48:00:00
""", out)
def test_chart_day_with_interval_over_whole_day(self):
self.t("track 2016-01-15T00:00:00 - 2016-01-16T00:00:00 XOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXO")
code, out, err = self.t("day 2016-01-15 - 2016-01-16")
self.assertIn("""\
\nFri 15 XOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXO\
\n XOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXOXO\
\n
Tracked 24:00:00
Available 0:00:00
Total 24:00:00
""", out)
if __name__ == "__main__":
from simpletap import TAPTestRunner
unittest.main(testRunner=TAPTestRunner())