# (c) cavaliba.com - tests / sirene / views

import app_home.cache as cache
from app_home.models import CavalibaConfiguration
from django.core.cache import cache as cache_django
from django.test import TestCase, override_settings
from django.urls import reverse
from tests import helper


class SireneViews(TestCase):

    fixtures = ["init"]

    def setUp(self):

        helper.add_admin_user(login="unittest")
        cache.clear()
        cache_django.clear()


    # Anonymous
    # ---------

    # not logged-in
    @override_settings(CAVALIBA_AUTH_MODE="local")
    def test_public(self):
        response = self.client.get(reverse('app_sirene:index'))
        self.assertEqual(response.status_code, 200)


    @override_settings(CAVALIBA_AUTH_MODE="local")
    def test_anonymous_ko(self):
        response = self.client.get(reverse('app_sirene:anonymous'))
        # print(response.content)
        self.assertEqual(response.status_code, 302)


    def test_trusted_ip_nologin(self):
        conf = CavalibaConfiguration.objects.get(
            appname="user", keyname="TRUSTED_ANONYMOUS_IPS")
        conf.value = "0.0.0.0/0"
        conf.save()

        response = self.client.get(reverse('app_sirene:anonymous'))
        self.assertEqual(response.status_code, 200)

        response = self.client.get(reverse('app_sirene:private'))
        self.assertEqual(response.status_code, 302)


    # user
    #  ----

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_user_public(self):
        response = self.client.get(reverse('app_sirene:index'))
        self.assertEqual(response.status_code, 200)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_user_anonymous(self):
        response = self.client.get(reverse('app_sirene:anonymous'))
        self.assertEqual(response.status_code, 200)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_user_private(self):
        response = self.client.get(reverse('app_sirene:private'))
        self.assertEqual(response.status_code, 200)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_user_archive(self):
        response = self.client.get(reverse('app_sirene:archive'))
        self.assertEqual(response.status_code, 200)

    # -- flush all GET/POST

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_user_flushall_get(self):
        response = self.client.post(reverse('app_sirene:close_all'), follow=True)
        a = ('/sirene/private/', 302)
        #print(response.redirect_chain)
        self.assertTrue(a in response.redirect_chain)


    # operator
    # --------

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_operator_public(self):
        response = self.client.get(reverse('app_sirene:index'))
        self.assertEqual(response.status_code, 200)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_operator_anonymous(self):
        response = self.client.get(reverse('app_sirene:anonymous'))
        self.assertEqual(response.status_code, 200)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_operator_private(self):
        response = self.client.get(reverse('app_sirene:private'))
        self.assertEqual(response.status_code, 200)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_operator_archive(self):
        response = self.client.get(reverse('app_sirene:archive'))
        self.assertEqual(response.status_code, 200)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_operator_smsjournal(self):
        #helper.add_admin_user()
        response = self.client.get(reverse('app_sirene:sms_journal'))
        self.assertEqual(response.status_code, 200)

    # -- flush all GET/POST

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_operator_flushall_get(self):
        response = self.client.get(reverse('app_sirene:close_all'), follow=True)
        # self.assertEqual(response.status_code, 302)
        a = ('/sirene/', 302)
        # print(response.redirect_chain)
        self.assertTrue(a in response.redirect_chain)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_operator_flushall_post(self):
        response = self.client.post(
            reverse('app_sirene:close_all'), follow=True)
        a = ('/sirene/private/', 302)
        # print(response.redirect_chain)
        self.assertTrue(a in response.redirect_chain)


    # admin
    # -----

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_admin_to_anonymous(self):
        response = self.client.get(reverse('app_sirene:anonymous'))
        # user = admin
        self.assertEqual(response.status_code, 200)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_admin_trusted_ip(self):
        conf = CavalibaConfiguration.objects.get(
            appname="user", keyname="TRUSTED_ANONYMOUS_IPS")
        conf.value = "0.0.0.0/0"
        conf.save()

        response = self.client.get(reverse('app_sirene:anonymous'))
        self.assertEqual(response.status_code, 200)

    @override_settings(CAVALIBA_AUTH_MODE="unittest")
    def test_admin_to_private_access(self):
        response = self.client.get(reverse('app_sirene:private'))
        self.assertEqual(response.status_code, 200)
