| Left: | ||
| Right: |
| OLD | NEW |
|---|---|
| (Empty) | |
| 1 #!/usr/bin/env python3 | |
| 2 | |
| 3 import os | |
| 4 import re | |
| 5 import datetime | |
| 6 import subprocess | |
| 7 import shutil | |
| 8 import urllib.parse | |
| 9 | |
| 10 import pytest | |
| 11 | |
| 12 from update_copyright import extract_urls, text_replace, hg_commit, main | |
| 13 | |
| 14 data_path = os.path.join(os.path.dirname(os.path.abspath(__file__)), 'data') | |
| 15 | |
| 16 | |
| 17 def create_repo(path): | |
| 18 print('19: Creating repo in: ', path) | |
|
Vasily Kuznetsov
2017/07/03 19:25:46
This looks like a debug print. It won't be visible
rosie
2017/07/04 13:38:25
Done.
| |
| 19 subprocess.check_call(['hg', 'init', path]) | |
| 20 with open(os.path.join(path, '.hg', 'hgrc'), 'w+') as hgrc: | |
| 21 set_user = '[ui]\nusername = Test User <test@example.com>' | |
| 22 hgrc.write(set_user) | |
| 23 shutil.copy(os.path.join(data_path, 'sample_file.py'), path) | |
| 24 subprocess.check_call(['hg', 'commit', '-Am', 'Initial commit', | |
| 25 '--repository', path]) | |
| 26 | |
| 27 | |
| 28 @pytest.fixture() | |
| 29 def temp_dir(tmpdir): | |
| 30 temp_dir = tmpdir.mkdir('temp_dir') | |
| 31 return temp_dir | |
| 32 | |
| 33 | |
| 34 @pytest.fixture() | |
| 35 def temp_repo(tmpdir): | |
| 36 """"Returns a path to a temporary repo containing one sample file""" | |
| 37 temp_repo = tmpdir.mkdir('tmp_dir') | |
| 38 create_repo(str(temp_repo)) | |
| 39 return temp_repo | |
| 40 | |
| 41 | |
| 42 @pytest.fixture() | |
| 43 def base_dir(tmpdir): | |
| 44 """Returns a temporary directory that contains one html page and two | |
| 45 repositories (one with push access, the other without)""" | |
| 46 tmp_repo = tmpdir.mkdir('tmp_dir') | |
| 47 temp_dir = str(tmp_repo) | |
| 48 subprocess.check_call(['cp', os.path.join(data_path, 'hg_page.html'), | |
| 49 temp_dir]) | |
| 50 repo_1 = str(os.path.join(temp_dir, 'repo_1')) | |
|
Vasily Kuznetsov
2017/07/03 19:25:46
Do you need the `str(...)` here? `os.path.join` re
rosie
2017/07/04 13:38:25
Done.
| |
| 51 repo_2 = str(os.path.join(temp_dir, 'repo_2')) | |
| 52 os.mkdir(repo_1) | |
| 53 os.mkdir(repo_2) | |
| 54 create_repo(repo_1) | |
| 55 create_repo(repo_2) | |
| 56 | |
| 57 # Make repo_2 read-only | |
| 58 with open(os.path.join(repo_2, '.hg/hgrc'), 'w') as hgrc: | |
| 59 hook = '[hooks]\npretxnchangegroup = return True' | |
| 60 hgrc.write(hook) | |
| 61 return temp_dir | |
| 62 | |
| 63 | |
| 64 def test_extract_urls(): | |
| 65 print('65: test_extract_urls') | |
|
Vasily Kuznetsov
2017/07/03 19:25:46
Also debug print ;)
rosie
2017/07/04 13:38:25
Done.
| |
| 66 data_url = urllib.parse.urljoin('file:///', data_path) | |
| 67 urls = [data_url + '/repo_1/', | |
| 68 data_url + '/repo_2/'] | |
| 69 assert urls == extract_urls(os.path.join(data_url, 'hg_page.html')) | |
| 70 | |
| 71 | |
| 72 def test_text_replacement(temp_repo): | |
| 73 print('73: test_text_replacement') | |
| 74 filename = temp_repo.join('sample_file.py').strpath | |
| 75 text_replace(temp_repo.strpath, filename) | |
| 76 with open(filename) as file: | |
| 77 text = file.read() | |
| 78 pattern = re.compile(r'(copyright.*?\d{4})(?:-\d{4})?\s+eyeo gmbh', | |
| 79 re.I) | |
| 80 for year in re.finditer(pattern, text): | |
| 81 dates = re.search(r'(\d{4})-(\d{4})', year.group(0)) | |
| 82 assert dates.group(2) == str(datetime.datetime.now().year) | |
| 83 | |
| 84 | |
| 85 def test_hg_commit(temp_repo, temp_dir): | |
| 86 print('86: test_hg_commit') | |
| 87 directory = str(temp_dir) | |
| 88 repo = str(temp_repo) | |
| 89 subprocess.check_call(['hg', 'clone', repo, directory]) | |
| 90 open(os.path.join(directory, 'foo'), 'w').close() | |
| 91 subprocess.check_call(['hg', 'add', '--repository', directory]) | |
| 92 hg_commit(directory, repo) | |
| 93 | |
| 94 # Make sure both files contain the commmit message from hg log | |
| 95 log_1 = subprocess.run(['hg', 'log', '--repository', repo], | |
| 96 stdout=subprocess.PIPE) | |
| 97 assert 'Noissue - Updated copyright year' in str(log_1.stdout) | |
| 98 | |
| 99 | |
| 100 def test_all(base_dir): | |
| 101 print('101: test_all') | |
| 102 main(urllib.parse.urljoin('file:///', os.path.join( | |
| 103 base_dir, 'hg_page.html')), None) | |
| 104 | |
| 105 # assert hg log for repo_1 | |
| 106 log_1 = subprocess.run(['hg', 'log', '--repository', | |
| 107 os.path.join(base_dir, 'repo_1')], | |
| 108 stdout=subprocess.PIPE) | |
| 109 assert 'Noissue - Updated copyright year' in str(log_1.stdout) | |
| 110 | |
| 111 # assert the .patch file for repo_2 | |
| 112 assert'Noissue - Updated copyright year' in open('repo_2.patch').read() | |
| 113 subprocess.call(['rm', 'repo_2.patch']) # cleanup | |
| OLD | NEW |