forked from xen-troops/build-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
README
145 lines (121 loc) · 6.6 KB
/
README
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
This is a set of build scripts used to deliver various types of
automated builds for xen-troops with Jenkins and Yocto
build_prod.py script
====================
build_prod.py is the runner script for the automated build system.
There are number of required and optional parameters.
Required parameters
==================
--machine - specifies machine for which the build is requested to run
NOTE: xt-distro will fail if machine requested
is not supported
--product - specifies product to build
NOTE: xt-distro will fail if product requested
is not supported
Optional parameters
===================
--build-type - specifies build type to perform:
* dailybuild - perform the build based on HEAD revisions of meta layers,
e.g. this is the latest snapshot.
This is the default behaviour if build-type is not specified.
* on_push - perform the build because some of the relevant repositories
has changed due to new commits
* on_request - out of band build was requested, this is equivalent to
forced daily build
* reconstruct - perform build which has happened before, e.g. use saved
build history to reconstruct that build
--branch - specify branch of product manifest.
Repo with product manifest is specified as 'xt_manifest_uri'
in configuration file, provided by '--config'.
Default value is 'master'.
--with-local-conf - generate local.conf for the build, e.g. make local.conf
from scratch that fits the requirements of the automated
build.
This is normally used with Jenkins.
--with-do-build - perform build after initialization. If this option is not
provided then build script stops execution right after it
has made all required preparations for the build, e.g.
all components fetched etc.
This is normally used with Jenkins.
--with-build-history - during the build collect and save build history in the
git repository, so this build can be reconstructed later
This is normally used with Jenkins.
--continue-build - continue existing build if any, do not clean up
This must not be used with Jenkins.
--config - use configuration file for tuning
--parallel-build - allow parallel build of domains.
This is useful for building on powerful machines or
build servers.
--prod_pulls - allow define the list of the pull requests applied to
the product's meta layer. Example: --prod_pulls "181,245"
--retain-sstate - Normally if a new build is started (either with
--with-do-build or without --continue-build) SSTATE_DIR
is removed. If retain argument is provided it is
guaranteed that SSTATE directory is not removed then.
This behaviour is intended for local (non build server)
builds where state caches use is preferred over clean
environment for every day development.
Configuration file
==================
In order to tune build script environment one can provide an optional
configuration file. Sections and values of the configuration file:
* [git] - this section allows changing:
- xt_history_uri - URI of the build-history repository to use
- xt_manifest_uri - URI of the product manifest repository to use
* [path]
- workspace_base_dir - this shall be the fastest storage
for performing all of the build tasks.
Usually, this is a folder on your SSD drive.
- workspace_storage_base_dir - place where artifacts of the build are stored
This is also used to store downloads and
shared sstate cache (can be shared with
other machines as sstate cache mirror).
- workspace_cache_base_dir - place where Yocto's SSTATE_DIR or ccache's
cache directories of the build are stored.
On machines which do not have enough room
on fast drives to hold both build itself and
caches this allows distributing those between
different storages.
Example of artifacts placement in the storage folder
====================================================
build-artifacts
└── dailybuild
├── 2017-05-26
└── prod-devel
└── salvator-x
├── 19-10-15
├── build-system-version_1.0
├── dom0-image-base
│ ├── build-versions.inc
│ ├── images
│ │ └── m3ulcb-dom0
│ ├── metadata-revs
│ └── sdk
├── domu-image-minimal
│ ├── build-versions.inc
│ ├── images
│ │ └── m3ulcb-domu
│ ├── metadata-revs
│ └── sdk
├── logs
│ ├── cooker
│ │ └── salvator-x
│ ├── dom0-image-base
│ └── domu-image-minimal
└── prod-devel-manifest.xml
Example of build history placement in the storage folder
========================================================
build-history
├── dailybuild
└── 2017-05-27
└── prod-devel
└── salvator-x
└── 09-24-52
├── build-system-version_1.0
├── dom0-image-base
│ ├── build-versions.inc
│ └── metadata-revs
├── domu-image-minimal
│ ├── build-versions.inc
│ └── metadata-revs
└── prod-devel.xml