blob: 2c93804ecceef944d893b03c205ec78800afe01b (
plain)
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
|
#!/usr/bin/env python
# Copyright (C) 2015 Codethink Limited
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; version 2 of the License.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program. If not, see <http://www.gnu.org/licenses/>.
'''Migration to Baserock Definitions format version 2.
In version 2, the processing of the 'morph:' field within stratum .morph files
became more strict. This migration checks whether definitions are valid
according to version 2 of the format.
'''
import os
import sys
import warnings
import migrations
TO_VERSION = 2
def check_missing_chunk_morphs(contents, filename):
assert contents['kind'] == 'stratum'
valid = True
for chunk_ref in contents.get('chunks', []):
if 'morph' in chunk_ref:
chunk_path = os.path.join('.', chunk_ref['morph'])
if not os.path.exists(chunk_path):
# There's no way we can really fix this, so
# just warn and say the migration failed.
warnings.warn(
"%s points to non-existant file %s" %
(contents['name'], chunk_ref['morph']))
valid = False
return valid
try:
if migrations.check_definitions_version(TO_VERSION - 1):
safe_to_migrate = migrations.process_definitions(
kinds=['stratum'], validate_cb=check_missing_chunk_morphs)
if not safe_to_migrate:
sys.stderr.write(
"Migration failed due to one or more warnings.\n")
sys.exit(1)
else:
migrations.set_definitions_version(TO_VERSION)
sys.stdout.write("Migration completed successfully.\n")
sys.exit(0)
else:
sys.stdout.write("Nothing to do.\n")
sys.exit(0)
except RuntimeError as e:
sys.stderr.write("Error: %s\n" % e.message)
sys.exit(1)
|