#!/usr/bin/python3
# -*- coding: utf-8 -*-
"""
Agenda test (inkycal_agenda)
Copyright by aceisace
"""
import unittest
from inkycal.modules import Agenda as Module
from helper_functions import *
environment = get_environment()

# Set to True to preview images. Only works on Raspberry Pi OS with Desktop
use_preview = False


sample_url = "https://www.officeholidays.com/ics-fed/usa"

tests = [
{
  "name": "Agenda",
  "config": {
    "size": [400, 200],
      "ical_urls": sample_url,
      "ical_files": None,
      "date_format": "ddd D MMM",
      "time_format": "HH:mm",
      "padding_x": 10,
      "padding_y": 10,
      "fontsize": 12,
      "language": "en"
  }
},
{
  "name": "Agenda",
  "config": {
    "size": [500, 800],
      "ical_urls": sample_url,
      "ical_files": None,
      "date_format": "ddd D MMM",
      "time_format": "HH:mm",
      "padding_x": 10,
      "padding_y": 10,
      "fontsize": 12,
      "language": "en"
  }
},
{
  "position": 1,
  "name": "Agenda",
  "config": {
    "size": [300, 800],
      "ical_urls": sample_url,
      "ical_files": None,
      "date_format": "ddd D MMM",
      "time_format": "HH:mm",
      "padding_x": 10,
      "padding_y": 10,
      "fontsize": 12,
      "language": "en"
  }
},
]


class module_test(unittest.TestCase):
  def test_get_config(self):
    print('getting data for web-ui...', end = "")
    Module.get_config()
    print('OK')

  def test_generate_image(self):
    for test in tests:
      print(f'test {tests.index(test)+1} generating image..')
      module = Module(test)
      im_black, im_colour = module.generate_image()
      print('OK')
      if use_preview == True and environment == 'Raspberry':
        preview(merge(im_black, im_colour))

if __name__ == '__main__':

  logger = logging.getLogger()
  logger.level = logging.DEBUG
  logger.addHandler(logging.StreamHandler(sys.stdout))

  unittest.main()