forked from bogdan23a/TheSeekNotebook
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathTest.py
More file actions
85 lines (57 loc) · 2.84 KB
/
Test.py
File metadata and controls
85 lines (57 loc) · 2.84 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
import unittest
from unittest.mock import patch
import SEEK
import WriteObject
import getpass
PROT_DEFAULT_AUTHENTICATION_STRING = "DEFAULT"
class TestSEEK(unittest.TestCase):
def setUp(self):
self.auth = (PROT_DEFAULT_AUTHENTICATION_STRING,
PROT_DEFAULT_AUTHENTICATION_STRING)
self.testObject = SEEK.module(self.auth)
self.testSearch = SEEK.module(self.auth)
def tearDown(self):
del self.auth
del self.testObject
# Testing object initialization with authentication
def test_InitWithAuth(self):
self.assertEqual(self.testObject.session.auth,
(PROT_DEFAULT_AUTHENTICATION_STRING,
PROT_DEFAULT_AUTHENTICATION_STRING),
"Request should have these credentials")
# Testing object initialization without authentication
@patch('SEEK.module.get_input', return_value=
PROT_DEFAULT_AUTHENTICATION_STRING)
@patch('getpass.getpass', return_value=PROT_DEFAULT_AUTHENTICATION_STRING)
def test_InitWithoutAuth(self ,username, password):
self.testObject = SEEK.module()
self.assertEqual(self.testObject.session.auth,
(PROT_DEFAULT_AUTHENTICATION_STRING,
PROT_DEFAULT_AUTHENTICATION_STRING),
"Request should require user input")
# def test_AuthNotWorking(self):
# Testing the request of an existent object
def test_RequestReturnsTrue(self):
self.assertTrue(self.testObject.request(type="assays", id="576"),
"This request should return true")
# Testing the request of an inexistent object
def test_RequestReturnsFalse(self):
self.assertFalse(self.testObject.request(type="assays", id="0"),
"This request should return false")
def test_RequestHasError(self):
self.testObject.base_url = "wrong.url.com"
self.assertRaises(Exception, self.testObject.request(type="assays",
id="576"),
"This request should return error")
@patch('SEEK.module.get_input', return_value='1')
def testSearchAdvancedSetup(self, input):
self.testSearch.searchAdvancedSetup()
self.assertEqual(self.testSearch.searchResultsPerThread, 1)
self.assertEqual(self.testSearch.relationshipsPerThread, 1)
@patch('SEEK.module.get_input', return_value='what')
def testSearchAdvancedSetupWithWrongInput(self, input):
self.testSearch.searchAdvancedSetup()
self.assertRaises(Exception, self.testSearch.searchResultsPerThread)
self.assertRaises(Exception, self.testSearch.relationshipsPerThread)
if __name__ == '__main__':
unittest.main()