-
Notifications
You must be signed in to change notification settings - Fork 3
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Get title #23
Get title #23
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Нужно исправить баги.
<title></title>
нужно забирать через регулярное выражение, см. замечания- Нужно проставить у запроса параметр
(verify=False)
, чтобы не было проблем с https переходами и др. - Нужно исправить тесты, сейчас они не тестируют функционал модуля. Для этого нужно изменить сервер, который мокается, добавить туда title тег и проверить, что твой модуль может его забрать.
Плюс Black линтинг, если не было, оптимизация импортов и др.
Буду ждать изменений!
#!/usr/bin/env python3 | ||
|
||
from unittest import TestCase | ||
from .module import Runner | ||
from http.server import HTTPServer, BaseHTTPRequestHandler | ||
from threading import Thread | ||
|
||
|
||
|
||
class GetTitleTest(TestCase): | ||
|
||
|
||
def setUp(self): | ||
""" | ||
Setup something before each test function | ||
:return: None | ||
""" | ||
self.runner = Runner() | ||
|
||
def test_create_runner(self) -> None: | ||
""" | ||
Test creation of the class instance | ||
:return: None | ||
""" | ||
self.assertIsNotNone(self.runner) | ||
self.assertIsInstance(self.runner, Runner) | ||
|
||
def test_remote_server(self) -> None: | ||
""" | ||
Test values from the remote server | ||
:return: None | ||
""" | ||
response = self.runner.run(username=None) | ||
self.assertEqual(response.get("status"), "success") | ||
response = self.runner.run(username="") | ||
self.assertEqual(response.get("status"), "success") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
А как этот файл сюда попал?
from pathlib import Path | ||
|
||
__root_dir = Path(__file__).parents[4] | ||
sys.path.append(str(__root_dir)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Добавить в конце пустую строчку
result = run_module( | ||
Runner, args=argv, arg_name="url", arg_default="johndoe@gmail.com" | ||
) | ||
pprint(result) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Добавить в конце пустую строчку
def __init__(self, logger: str = __name__): | ||
super(Runner, self).__init__(logger) | ||
|
||
def run(self, *args, **kwargs): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
:return: http title if it's exist | ||
""" | ||
url = kwargs.get("url") | ||
response = None |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Этого response = None
не нужно, достаточно просто изменить try / except
блок
response = None | ||
result = "None title or Bad url" | ||
try: | ||
response = requests.get(url) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Добавить verify=False
параметр
if response.find("<title>") != -1 and response.find("</title>") != -1: | ||
try: | ||
result = response[ | ||
response.find("<title>") + 7 : response.find("</title>") | ||
] | ||
except: | ||
pass | ||
return ScriptResponse.success( | ||
result=result, message="Title on {url} is: ".format(url=url) | ||
) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Вот это всё заменить на
from re import search
...
search_title = search(r"<title>(.*)</title>", response)
return ScriptResponse.success(
result=search_title.group(1) if search_title else None, message="Title on {url} is: ".format(url=url)
)
except: | ||
pass | ||
return ScriptResponse.success( | ||
result=result, message="Title on {url} is: ".format(url=url) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Заменить мессадж на что-нибудь типа f"Successfully found the title for {url}"
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
И кстати, сейчас сообщение не полное - после двоеточия же ничего не пишется?
) | ||
|
||
|
||
class GetTitleTest(TestCase): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
В этом тесте не тестируется функционал модуля вообще.
Т.е., тебе нужно убедиться, что твой модуль правильно находит html тайтл тег и возвращает его значение. Но в этом тесте ты просто поднимаешь сервер и больше не делаешь ничего, связанного с функционалом модуля. Нужно протестировать, что ты можешь забрать тайтл нормально и он соответствует действительности. Для этого нужно в своем локальном сервисе на странице сделать <title></title>, написать какой-то тайтл, и проверить, что твой модуль может его правильно получить и он равен тому же тайтлу, что и на сервере.
self.send_header("Content-type", "text/html; charset=utf-8") | ||
self.end_headers() | ||
self.wfile.write( | ||
b"<html><body><i>Mock page from Mocking Class</i></body></html>" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Здесь нужно добавить ещё какой-нибудь тайтл, чтобы проверить, что твой модуль может его забрать.
add new lines in __main__.py and __init__.py
fixed(92723d4) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Я немного переписал и подправил некоторые моменты
* WIP: Add Initial Version (alpha-beta-gamma) (#1) * Add initial WIP project version * Update src code * Update documentation * Add requirements * add script name_check (#4) * Add initial WIP project version * add check_nickname.py, check_nickname_sync and check_nickname_async in it add social_networks.txt * add check_nickname.py, check_nickname_sync and check_nickname_async in it add social_networks.txt * new main.py * new base: develop add many files * fix inheritance in Runner * fix check_nickname fix social_networks.txt * Little fixes * Return default main value Co-authored-by: manmolecular <regwebghost@yandex.ru> * Add script: region check (#5) * Added number to Possiblekeys in osint.py. Added number as kwarg in main.py. Script defines the region where the phone number is registrated * Changed number->phone * Little fixes, update requirements Co-authored-by: manmolecular <regwebghost@yandex.ru> * add script (email_verifier) (#7) * add script (email_verifier) * add library * change req and so on * used black * Little fixes * Main and .gitignore fixes Co-authored-by: Minerm <minerm@mail.ru> Co-authored-by: manmolecular <regwebghost@yandex.ru> * Add script to get allowed http methods. (#10) * Add script to get allowed http methods. * 'Handle' more probable exceptions * Changed name of script directory * Remove wildcard import * Add random method check. Alter script response. * Little fixes * Fix methods variable * Fix typo in requirements Co-authored-by: manmolecular <regwebghost@yandex.ru> * Add script to calculate hash of favicon.ico for Shodan (#13) * Add script to calculate hash of favicon.ico * Remove '\n' * Change variable name * Core fixes. Provide global variables. Update runner. Upgrade module-package system. (#14) * Clean init all the modules with the __init__.py file * Remove unused gitkeeps * Add base inits for script packages * Update main file * Set __file__ variable at the module level * Add inits for the modules * Modify all the modules * Delete one more .gitkeep * Add WIP test for user_greeting * Update test module for user_greeting * Fix module runner a bit * Add relative imports to the modules * Add run tests script * Update README.md * Fix module-package runner * Update requirements * Format everything with Black * Handle module and execution errors with runner * Awesome cookie checker (#6) * made cookie checker task * added requirements.txt * refactored the code & adapted to the new project structure * small fix that processes exception * Little fixes Co-authored-by: manmolecular <regwebghost@yandex.ru> * Added a function for retrieving location and provider info by IP address. (#12) * Added IP address as one of the possible keys. * Init commit. * Init commit. * Added dosctring. * Removed some emptry lines. * get_ip_info was moved into Runner class. * The IP key shouldn't be here. * Reworked exception handling mechanism. * Codestyle fix. * Removed some test code. * Moved script to proper dir. * Fixed response returned in case of error. * Fixed exception handling. * Request now uses the validated IP. * Found a better variable name for validated IP. * Removed unnecessary variables. * Init commit. * Runner class was moved into this module. * Set default IP to Google DNS Resolver address (to be more stable) * Add default values; set default ip to 8.8.8.8; set default city to Ashburn * Apply Black linter on the main module file Co-authored-by: manmolecular <regwebghost@yandex.ru> * Add simple server mocking test example (#20) * Add simple web server mocking example * Add some types * Add tests for favicon hash (#22) * Add tests for favicon hash * Apply Black linting * Suppress server output logging Co-authored-by: manmolecular <regwebghost@yandex.ru> * Test allowed_methods. Modify allowed_methods. (#21) * * Make allowed_methods also return methods on which server did not response. * Add tests for allowed_methods module. * Fix output * Change docstring * Linting with Black Co-authored-by: manmolecular <regwebghost@yandex.ru> * Fix tests timeouts (#25) * Add tests defaults (#26) * Boost up/improvement: Add multiprocessing CaseManager (processes, threads, parallel case execution) (#27) * Add multiprocessing CaseManager * Add more info about case to the manager * Update logging format * Set optimal threads and processes quantity * simple email generator (#9) * Made simple email generator, modified requirements.txt * deleted __main__ rubbish, modified success message * added a check on username availability * Update __main__.py * Update __main__.py * modified names of methods and atributes * Update requirements.txt * reduced number of domen names, possible emails; reduced reversing and optimized code; moved project to convert/ dir; led project to a new view * fixed bug with command prompt; got rid of json; moved service symbols to a separate class; optimized code; made cosmetic changes * some fixes * some fixes * Add fixes Co-authored-by: manmolecular <regwebghost@yandex.ru> * Added phone number generator and normaliser script file (#11) * Added phone number generator and normaliser script file * Added feature directory and empty files * Added module.py * Added Runner class to main.py * Cleaned up the comments and reformatted code * Added library to the main requirements.txt * Changed module.py * Changed module.py * Deleted old script file * Fixed requirements bug * Add phone_num_generator module * Corrected double brackets and dot format mistakes * Something went wrong last time, so no2 * Added unittests and local number format * Fix main module runner * Remove code duplicate Co-authored-by: manmolecular <regwebghost@yandex.ru> * Get title (#23) * add main code * add __init__.py,__main__.py,module.py,test_module.py * fix module.py fix test_module.py * add test_module.py * add requirements.txt * fix tests,module.py add new lines in __main__.py and __init__.py * Remove old format string * Delete test_module from check_nickname * Module fixes Co-authored-by: manmolecular <regwebghost@yandex.ru> * Suppress Requests keep-alive socket warnings (#33) * Iknowwhatyoudownload (#24) * added torrent module * underscores bugfix * added docstrings * updated requirements * changed directory * Added required changes * Fix base runners * Remove API key, fix main runner * Linting with Black Co-authored-by: omarkelov <36790281+omarkelov@users.noreply.github.com> Co-authored-by: Anton Nikolaev <regwebghost@yandex.ru> * add test_module.py in email_verifier (#29) * add test_module.py * Add functions (test_pass_false / true_arguments) * Fix comparison * Fix return types Co-authored-by: Minerm <minerm@mail.ru> Co-authored-by: manmolecular <regwebghost@yandex.ru> * Fix validator keys (#35) * Develop: fixes, improvements, etc. (#36) * Suppress insecure request warning messages * Update requirements.txt * Add base scenario, add yaml support * Update structure; include results saving * Improvements - skip not applicable scripts, fix workers system (#39) * Fix executors * Optimize imports * Add results to gitignore * Add 'required' field to define required args * Ignore results from 'results' directory * Add 'required' field to base classes * Skip not applicable scripts * Fix quantity of processes * Set the execution timeout to 5 mins per case * Add phone case to the examples * JSON Russian language and encoding support * Add core default values * Remove hardcoded quantity of workers * Increase quantity of cases up to 10 * Fix indentation in runner * Add seed (initial) data to scan for * Email generator fix and tests (#38) * added tests * fixed incorrect behavior * extension of tests, cosmetic changes * Add google_search module (#37) * Add module scraping search results. * Add tests to google_search script * Add tests and do minor refactoring * Add input type test * Apply black linting * Add request delay when needed * Remove redundant import * Fixes (#40) * Add 'required' field for the google search module * Add beatifulsoup to requirements * Check nickname (#28) * add main code * add __init__.py,__main__.py,module.py,test_module.py * fix module.py fix test_module.py * add test_module.py * add requirements.txt * fix tests,module.py add new lines in __main__.py and __init__.py * add test_module.py * delete get_title * add some tests to test_module.py fix social_networks.txt * fix styles modify social_networks.txt * fix module.py fix test_module.py * Cosmetic fixes Co-authored-by: manmolecular <regwebghost@yandex.ru> * Update README.md * Add Tornado-based web-server. Support REST API methods. Implement task manager. (#41) * Modify environment files * Move saver to another module * Add SQLite database handling * Add Tornado server * Add main server runner * Move saver to another module * Add multiprocessing * Add docker-compose and postgres * Update database handling * Update environment files * Remove unused imports from main.py * Update database handlers * Update task manager; handle task status * Fix task spawner * Little cosmetic fixes, format files * Format with Black * Add environment variables * Add limit parameter to the task list handler * Don't initialize task spawner, it's not required * Remove single case wrapper from the main.py * Add Docker support for server * Fix makefile: spaces to tabs * Format with Black * Cosmetic: add new line to dockerignore * Add healthcheckers * Add CLI interface * Add color logging * Update gitignore * Add parents for scripts in logging * Fix makefile * Add screenshots * Update README.md * Update README.md Co-authored-by: Iandmee <48530455+Iandmee@users.noreply.github.com> Co-authored-by: sph-668 <68100447+sph-668@users.noreply.github.com> Co-authored-by: Neo <55306931+Shas08@users.noreply.github.com> Co-authored-by: Minerm <minerm@mail.ru> Co-authored-by: Nikita Kryukov <cravtos92@gmail.com> Co-authored-by: HochuOlivie <49933393+HochuOlivie@users.noreply.github.com> Co-authored-by: Timur <36272321+SN4KEBYTE@users.noreply.github.com> Co-authored-by: Matvey Sergeev <47077074+Enhisir@users.noreply.github.com> Co-authored-by: marinepalyan <50265835+marinepalyan@users.noreply.github.com> Co-authored-by: katerina <42969775+edubinskaya18214@users.noreply.github.com> Co-authored-by: omarkelov <36790281+omarkelov@users.noreply.github.com>
No description provided.