-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtasks.py
164 lines (126 loc) · 4.47 KB
/
tasks.py
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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
import os
from datetime import datetime
from babel.messages.pofile import read_po, write_po
from babel.util import LOCALTZ
from invoke import task, call
ROOT = os.path.abspath(os.path.join(os.path.dirname(__file__)))
I18N_ROOT = 'udata_recommendations/translations'
LANGUAGES = ['fr']
TO_CLEAN = ['build', 'dist', '**/*.pyc', 'reports']
def color(code):
'''A simple ANSI color wrapper factory'''
return lambda t: '\033[{0}{1}\033[0;m'.format(code, t)
green = color('1;32m')
red = color('1;31m')
blue = color('1;30m')
cyan = color('1;36m')
purple = color('1;35m')
white = color('1;39m')
def header(text):
'''Display an header'''
print(' '.join((blue('>>'), cyan(text))))
def info(text, *args, **kwargs):
'''Display informations'''
text = text.format(*args, **kwargs)
print(' '.join((purple('>>>'), text)))
def success(text):
'''Display a success message'''
print(' '.join((green('>>'), white(text))))
def error(text):
'''Display an error message'''
print(red('✘ {0}'.format(text)))
@task
def clean(ctx):
'''Cleanup all build artifacts'''
header(clean.__doc__)
with ctx.cd(ROOT):
for pattern in TO_CLEAN:
info('Removing {0}', pattern)
ctx.run('rm -rf {0}'.format(pattern))
@task
def test(ctx, report=False):
'''Run tests suite'''
cmd = 'pytest -v'
if report:
cmd = ' '.join((cmd, '--junitxml=reports/tests.xml'))
with ctx.cd(ROOT):
ctx.run(cmd, pty=True)
@task
def cover(ctx, html=False):
'''Run tests suite with coverage'''
cmd = 'pytest --cov udata_recommendations --cov-report term'
if html:
cmd = ' '.join((cmd, '--cov-report html:reports/cover'))
with ctx.cd(ROOT):
ctx.run(cmd, pty=True)
@task
def qa(ctx):
'''Run a quality report'''
header(qa.__doc__)
with ctx.cd(ROOT):
info('Python Static Analysis')
flake8_results = ctx.run('flake8 udata_recommendations', pty=True, warn=True)
if flake8_results.failed:
error('There is some lints to fix')
else:
success('No lint to fix')
if flake8_results.failed:
error('Quality check failed')
exit(flake8_results.return_code)
success('Quality check OK')
def set_po_metadata(filename, locale):
# Fix crowdin requiring Language with `2-digit` iso code in potfile
# to produce 2-digit iso code pofile
# Opening the catalog also allows to set extra metadata
with open(filename, 'rb') as infile:
catalog = read_po(infile, locale)
catalog.copyright_holder = 'Etalab'
catalog.msgid_bugs_address = '[email protected]'
catalog.language_team = 'Data.gouv.fr Team <[email protected]>'
catalog.last_translator = 'Data.gouv.fr Team <[email protected]>'
catalog.revision_date = datetime.now(LOCALTZ)
with open(filename, 'wb') as outfile:
write_po(outfile, catalog, width=80)
@task
def i18n(ctx, update=False):
'''Extract translatable strings'''
header(i18n.__doc__)
# Python translations
info('Extract python translations')
with ctx.cd(ROOT):
ctx.run('python setup.py extract_messages')
set_po_metadata(os.path.join(I18N_ROOT, 'recommendations.pot'), 'en')
for lang in LANGUAGES:
pofile = os.path.join(I18N_ROOT, lang, 'LC_MESSAGES', 'recommendations.po')
if not os.path.exists(pofile):
ctx.run('python setup.py init_catalog -l {}'.format(lang))
set_po_metadata(pofile, lang)
elif update:
ctx.run('python setup.py update_catalog -l {}'.format(lang))
set_po_metadata(pofile, lang)
success('Updated translations')
@task
def i18nc(ctx):
'''Compile translations'''
header(i18nc.__doc__)
# Plugin translations (harvesters, views...)
info('Compile plugin translations')
with ctx.cd(ROOT):
ctx.run('python setup.py compile_catalog')
success('Compiled translations')
@task(i18nc)
def dist(ctx, buildno=None):
'''Package for distribution'''
header('Building a distribuable package')
cmd = ['python setup.py']
if buildno:
cmd.append('egg_info -b {0}'.format(buildno))
cmd.append('bdist_wheel')
with ctx.cd(ROOT):
ctx.run(' '.join(cmd), pty=True)
ctx.run('twine check dist/*')
success('Distribution is available in dist directory')
@task(clean, qa, call(test, report=True), dist, default=True)
def default(ctx):
'''Perform quality report, tests and packaging'''
pass