#!/usr/bin/env vpython3
# Copyright (c) 2020 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

"""Unit tests for rdb_wrapper.py"""

from __future__ import print_function

import json
import logging
import os
import requests
import sys
import time
import unittest

if sys.version_info.major == 2:
  import mock
  BUILTIN_OPEN = '__builtin__.open'
else:
  from unittest import mock
  BUILTIN_OPEN = 'builtins.open'

sys.path.insert(0, os.path.dirname(os.path.dirname(os.path.abspath(__file__))))

import rdb_wrapper

class TestSetupRDB(unittest.TestCase):

  def setUp(self):
    super(TestSetupRDB, self).setUp()
    mock.patch(BUILTIN_OPEN, mock.mock_open(read_data =
      '''{"result_sink":{"address": "fakeAddr","auth_token" : "p@$$w0rD"}}''')
      ).start()
    mock.patch('os.environ', {'LUCI_CONTEXT': 'dummy_file.txt'}).start()
    mock.patch('requests.post').start()
    mock.patch('time.time', side_effect=[1.0, 2.0, 3.0, 4.0, 5.0]).start()

  def test_setup_rdb(self):
    with rdb_wrapper.setup_rdb("_foobar", './my/folder/') as my_status_obj:
      self.assertEqual(my_status_obj.status, rdb_wrapper.STATUS_PASS)
      my_status_obj.status = rdb_wrapper.STATUS_FAIL

    expectedTr = {
        'testId'  : './my/folder/:_foobar',
        'status'  : rdb_wrapper.STATUS_FAIL,
        'expected': False,
        'duration': '1.000000000s'
    }

    requests.post.assert_called_once_with(
        url='http://fakeAddr/prpc/luci.resultsink.v1.Sink/ReportTestResults',
        headers={
            'Content-Type': 'application/json',
            'Accept': 'application/json',
            'Authorization': 'ResultSink p@$$w0rD'
        },
        data=json.dumps({'testResults': [expectedTr]})
    )

  def test_setup_rdb_exception(self):
    with self.assertRaises(Exception):
      with rdb_wrapper.setup_rdb("_foobar", './my/folder/'):
        raise Exception("Generic Error")

    expectedTr = {
        'testId': './my/folder/:_foobar',
        'status': rdb_wrapper.STATUS_FAIL,
        'expected': False,
        'duration': '1.000000000s'
    }

    requests.post.assert_called_once_with(
        url='http://fakeAddr/prpc/luci.resultsink.v1.Sink/ReportTestResults',
        headers={
            'Content-Type': 'application/json',
            'Accept': 'application/json',
            'Authorization': 'ResultSink p@$$w0rD'
        },
        data=json.dumps({'testResults': [expectedTr]})
    )

if __name__ == '__main__':
  logging.basicConfig(
      level=logging.DEBUG if '-v' in sys.argv else logging.ERROR)
  unittest.main()