# Copyright 2020 Red Hat, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
#      http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.

from selenium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
from selenium.common.exceptions import TimeoutException
import time

testinfra_hosts = ['paste01.opendev.org']


def test_lodgeit_container_web_listening(host):
    paste_http = host.socket("tcp://127.0.0.1:80")
    assert paste_http.is_listening

    paste_https = host.socket("tcp://127.0.0.1:443")
    assert paste_https.is_listening

def test_paste(host):
    cmd = host.run('curl --insecure '
                   '--resolve paste.opendev.org:443:127.0.0.1 '
                   'https://paste.opendev.org')
    assert 'New Paste' in cmd.stdout

def test_paste_robots(host):
    cmd = host.run('curl --insecure '
                   '--resolve paste.opendev.org:443:127.0.0.1 '
                   'https://paste.opendev.org/robots.txt')
    assert 'Disallow: /' in cmd.stdout

def test_paste_screenshots(host):
    driver = webdriver.Remote(
        command_executor='http://%s:4444/wd/hub' % (host.backend.get_hostname()),
        desired_capabilities=webdriver.DesiredCapabilities.FIREFOX)

    try:
        driver.get("https://localhost")
        WebDriverWait(driver, 30).until(lambda driver: driver.execute_script(
            'return document.readyState') == 'complete')
        time.sleep(5)
        driver.save_screenshot("/var/log/screenshots/paste-main-page.png")

    except TimeoutException as e:
        raise e
    finally:
        driver.quit()