-
Notifications
You must be signed in to change notification settings - Fork 36
/
Copy pathafb.sh
executable file
·118 lines (107 loc) · 5.53 KB
/
afb.sh
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
#!/bin/bash
###############################################################################
# FORMAT BUMPS
#
# A format defines a range of OS versions that have compatible update metadata
# and content. An update client can update a system from the oldest version in
# the format to the latest version in the format without worrying about
# compatibility issues in the update content for the version it is updating to.
#
# A format bump occurs when the update metadata or content is changed in such a
# way that will cause client updates to break. In this case the format number
# must be incremented so clients will not attempt to update to the new versions
# in the new format without crossing the format boundary. Update clients update
# only to the latest build in their format. Once that update is complete the
# update client may then update forward again because the last version in the
# current format has identical content to the first version in the new format,
# including the new update client needed to understand the new format.
#
# Clients must be able to update to the latest version in their format using
# the update metadata it understands. Once it is on that version it should also
# be on the new format. To achieve this the following steps must be taken.
###############################################################################
###############################################################################
# test setup
###############################################################################
# test workspace
mkdir afb-test
pushd afb-test
# init minimal mix with original format
mixer init --no-default-bundles --format 1
# create bundle to be deleted
mixer bundle create foo
# mark as deleted
sed -i "s/\(# \[STATUS\]:\).*/\1 Deprecated/" local-bundles/foo
# add minimal bundles including deleted bundle
mixer bundle add os-core os-core-update foo
###############################################################################
# +0
#
# This is the last normal build in the original format. When doing a format
# bump this build already exists. Building it now because the test needs a
# normal starting version.
###############################################################################
# build bundles and updates regularly
mixer build bundles
mixer build update
###############################################################################
# +10
#
# This is the last build in the original format. At this point add ONLY the
# content relevant to the format bump to the mash to be used. Relevant content
# should be the only change.
#
# mixer will create manifests and update content based on the format it is
# building for. The format is set in the mixer.state file.
###############################################################################
# update mixer to build version 20, which in our case is the +10
mixer versions update --mix-version 20
# build bundles normally. At this point the bundles to be deleted should still
# be part of the mixbundles list and the groups.ini
mixer build bundles
# remove all deleted bundles' content by replacing bundle-info files with empty
# directories. This causes mixer to fall back to reading content for those
# bundles from a chroot. The chroots for these bundles will be empty.
for i in $(grep -lir "\[STATUS\]: Deprecated" upstream-bundles/ local-bundles/); do
b=$(basename $i)
rm -f update/image/20/$b-info; mkdir update/image/20/$b
done
# Replace the +10 version in the version metadata files (/usr/lib/os-release
# and /usr/share/clear/version) with +20 version and write the new format to
# the format file on disk. This is so clients will already be on the new
# format when they update to the +10 because the content is the same as the
# +20.
sed -i 's/\(VERSION_ID=\).*/\130/' update/image/20/full/usr/lib/os-release
echo -n 30 > update/image/20/full/usr/share/clear/version
echo 2 > update/image/20/full/usr/share/defaults/swupd/format
# build update based on the modified bundle information. This is *not* a
# minversion and these manifests must be built with the mixer from the original
# format (if manifest format changes).
mixer build update
###############################################################################
# +20
#
# This is the first build in the new format. The content is the same as the +10
# but the manifests might be created differently if a new manifest template is
# defined for the new format.
###############################################################################
# update mixer to build version 30, which in our case is the +20
mixer versions update --mix-version 30 --skip-format-check
# update mixer.state to new format
sed -i 's/\(FORMAT\).*/\1 = "2"/' mixer.state
# Fully remove deleted bundles from groups.ini and mixbundles list. This will
# cause the deprecated bundles to be removed from the MoM entirely. This will
# not break users who had these bundles because the removed content in the +10
# caused the bundles to be dropped from client systems at that point.
for i in $(grep -lir "\[STATUS\]: Deprecated" upstream-bundles/ local-bundles/); do
b=$(basename $i)
mixer bundle remove $b; sed -i "/\[$b\]/d;/group=$b/d" update/groups.ini;
done
# link the +10 bundles to the +20 so we are building the update with the same
# underlying content. The only things that might change are the manifests
# (potentially the pack and full-file formats as well, though this is very
# rare).
cp -al update/image/20 update/image/30
# build an update as a minversion, this is the first build where the manifests
# identify as the new format
mixer build update --min-version 30 --skip-format-check