Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Unified Diff: update-copyright/tests/test_update_copyright.py

Issue 29493601: Issue 5431 - Fix test for copyright update script (Closed) Base URL: https://hg.adblockplus.org/codingtools
Patch Set: Created July 20, 2017, 1:38 p.m.
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « update-copyright/tests/data/sample_file.py ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: update-copyright/tests/test_update_copyright.py
===================================================================
--- a/update-copyright/tests/test_update_copyright.py
+++ b/update-copyright/tests/test_update_copyright.py
@@ -9,16 +9,29 @@
import pytest
from update_copyright import extract_urls, text_replace, hg_commit, main
data_path = os.path.join(os.path.dirname(os.path.abspath(__file__)), 'data')
+@pytest.fixture(scope='module')
+def generate_sample_file():
Vasily Kuznetsov 2017/07/20 15:01:30 It would be a bit more clear to call the fixture `
rosie 2017/08/03 17:52:45 Done.
+ # Generate sample_file.py programmatically
+ text = '# {}right (C) 2006-2015 eyeo GmbH\n'.format('Copy')
Vasily Kuznetsov 2017/07/20 15:01:30 If is important to have different years in differe
rosie 2017/08/03 17:52:45 The third line uses 'example GmbH' instead of 'eye
Vasily Kuznetsov 2017/08/04 16:54:46 Acknowledged.
+ text += "value = '{}right (C) 2006-2016 Eyeo GmbH'\n".format('Copy')
+ text += '# {}right (C) 2006-2014 example GmbH'.format('Copy')
+ sample_file = open(os.path.join(data_path, 'sample_file.py'), 'w')
Vasily Kuznetsov 2017/07/20 15:01:30 Would it work to create this file in a temporary d
Vasily Kuznetsov 2017/07/20 15:01:30 You could use `with` here instead, then you don't
rosie 2017/08/03 17:52:45 Done.
rosie 2017/08/03 17:52:45 Done.
+ sample_file.write(text)
+ sample_file.close()
+ yield generate_sample_file # teardown
+ subprocess.call(['rm', os.path.join(data_path, 'sample_file.py')])
+
+
def create_repo(path):
subprocess.check_call(['hg', 'init', path])
with open(os.path.join(path, '.hg', 'hgrc'), 'w+') as hgrc:
set_user = '[ui]\nusername = Test User <test@example.com>'
hgrc.write(set_user)
shutil.copy(os.path.join(data_path, 'sample_file.py'), path)
subprocess.check_call(['hg', 'commit', '-Am', 'Initial commit',
'--repository', path])
@@ -62,17 +75,17 @@
def test_extract_urls():
data_url = urllib.parse.urljoin('file:///', data_path)
urls = [data_url + '/repo_1/',
data_url + '/repo_2/']
assert urls == extract_urls(os.path.join(data_url, 'hg_page.html'))
-def test_text_replacement(temp_repo):
+def test_text_replacement(generate_sample_file, temp_repo):
updated = 0
filename = temp_repo.join('sample_file.py').strpath
text_replace(temp_repo.strpath, filename)
with open(filename) as file:
text = file.read()
pattern = re.compile(r'(copyright.*?\d{4})(?:-\d{4})?\s+eyeo gmbh',
re.I)
for year in re.finditer(pattern, text):
@@ -108,8 +121,9 @@
log_1 = subprocess.run(['hg', 'log', '--repository',
os.path.join(base_dir, 'repo_1')],
stdout=subprocess.PIPE)
assert 'Noissue - Updated copyright year' in str(log_1.stdout)
# assert the .patch file for repo_2
assert'Noissue - Updated copyright year' in open('repo_2.patch').read()
subprocess.call(['rm', 'repo_2.patch']) # cleanup
+ # subprocess.call(['rm', os.path.join(data_path, 'sample_file.py')])
« no previous file with comments | « update-copyright/tests/data/sample_file.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld