From b4a95628063341d6a884c51030b2ddfda4319241 Mon Sep 17 00:00:00 2001 From: "Christopher K. Hoadley" Date: Sun, 14 Jul 2019 18:31:55 -0500 Subject: [PATCH 1/2] Update tests.all.SherlockDetectTests so it will only run tests against the detection methods. This was the original intent for this class, but there was no test to ensure that the sites listed did not have their detection method changed. Now, the test will fail if it does not really cover a given category. --- tests/all.py | 110 +++++++++++++++++++++++++++++++++++++++++++-------- 1 file changed, 93 insertions(+), 17 deletions(-) diff --git a/tests/all.py b/tests/all.py index 064cd6d3..c5b99c6d 100644 --- a/tests/all.py +++ b/tests/all.py @@ -7,26 +7,30 @@ import unittest class SherlockDetectTests(SherlockBaseTest): - def test_detect_true(self): - """Test Username Existence Detection. + def test_detect_true_via_message(self): + """Test Username Does Exist (Via Message). - This test ensures that the mechanism of ensuring that a Username - exists works properly. + This test ensures that the "message" detection mechanism of + ensuring that a Username does exist works properly. Keyword Arguments: self -- This object. Return Value: N/A. - Will trigger an assert if Usernames which are known to exist are - not detected. + Will trigger an assert if detection mechanism did not work as expected. """ - self.username_check(['jack'], ['Twitter'], exist_check=True) - self.username_check(['dfox'], ['devRant'], exist_check=True) - self.username_check(['blue'], ['Pinterest'], exist_check=True) - self.username_check(['kevin'], ['Instagram'], exist_check=True) - self.username_check(['zuck'], ['Facebook'], exist_check=True) + site = 'Instagram' + site_data = self.site_data_all[site] + + #Ensure that the site's detection method has not changed. + self.assertEqual("message", site_data["errorType"]) + + self.username_check([site_data["username_claimed"]], + [site], + exist_check=True + ) return @@ -44,13 +48,46 @@ class SherlockDetectTests(SherlockBaseTest): Will trigger an assert if detection mechanism did not work as expected. """ - self.username_check(['jackkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk'], - ['Instagram'], + site = 'Instagram' + site_data = self.site_data_all[site] + + #Ensure that the site's detection method has not changed. + self.assertEqual("message", site_data["errorType"]) + + self.username_check([site_data["username_unclaimed"]], + [site], exist_check=False ) return + def test_detect_true_via_status_code(self): + """Test Username Does Exist (Via Status Code). + + This test ensures that the "status code" detection mechanism of + ensuring that a Username does exist works properly. + + Keyword Arguments: + self -- This object. + + Return Value: + N/A. + Will trigger an assert if detection mechanism did not work as expected. + """ + + site = 'Facebook' + site_data = self.site_data_all[site] + + #Ensure that the site's detection method has not changed. + self.assertEqual("status_code", site_data["errorType"]) + + self.username_check([site_data["username_claimed"]], + [site], + exist_check=True + ) + + return + def test_detect_false_via_status_code(self): """Test Username Does Not Exist (Via Status Code). @@ -65,13 +102,46 @@ class SherlockDetectTests(SherlockBaseTest): Will trigger an assert if detection mechanism did not work as expected. """ - self.username_check(['jackkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk'], - ['Facebook'], + site = 'Facebook' + site_data = self.site_data_all[site] + + #Ensure that the site's detection method has not changed. + self.assertEqual("status_code", site_data["errorType"]) + + self.username_check([site_data["username_unclaimed"]], + [site], exist_check=False ) return + def test_detect_true_via_response_url(self): + """Test Username Does Exist (Via Response URL). + + This test ensures that the "response URL" detection mechanism of + ensuring that a Username does exist works properly. + + Keyword Arguments: + self -- This object. + + Return Value: + N/A. + Will trigger an assert if detection mechanism did not work as expected. + """ + + site = 'Quora' + site_data = self.site_data_all[site] + + #Ensure that the site's detection method has not changed. + self.assertEqual("response_url", site_data["errorType"]) + + self.username_check([site_data["username_claimed"]], + [site], + exist_check=True + ) + + return + def test_detect_false_via_response_url(self): """Test Username Does Not Exist (Via Response URL). @@ -86,8 +156,14 @@ class SherlockDetectTests(SherlockBaseTest): Will trigger an assert if detection mechanism did not work as expected. """ - self.username_check(['jackkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk'], - ['Pinterest'], + site = 'Quora' + site_data = self.site_data_all[site] + + #Ensure that the site's detection method has not changed. + self.assertEqual("response_url", site_data["errorType"]) + + self.username_check([site_data["username_unclaimed"]], + [site], exist_check=False ) From ea361fb15601950fcb2b4b4e11bdc2ca4056bf61 Mon Sep 17 00:00:00 2001 From: "Christopher K. Hoadley" Date: Sun, 14 Jul 2019 18:35:02 -0500 Subject: [PATCH 2/2] Update Travis CI so that it only runs the tests.all.SherlockDetectTests. There are always failures in the coverage tests because one site or the other ends up having problems connecting. While the CI tests will not do complete coverage, at least they will test something. --- .travis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 97d56b14..89abd1b8 100644 --- a/.travis.yml +++ b/.travis.yml @@ -17,7 +17,7 @@ before_script: # exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide - flake8 . --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics script: - - python -m unittest tests.all --buffer --verbose || true + - python -m unittest tests.all.SherlockDetectTests --buffer --verbose || true notifications: on_success: change on_failure: change # `always` will be the setting once code changes slow down