forked from ottok/mariadb-10.0
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.Maintainer
193 lines (129 loc) · 6.32 KB
/
README.Maintainer
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
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
# README for Debian package maintainers #
This file mostly applies to how the packaging work-flow works for the official
Debian packages, but it may contain useful information also for anybody doing
their own private .deb builds.
## Building from sources with git-buildpackage ##
Clone sources with all branches
sudo apt-get install git-buildpackage
gbp-clone --pristine-tar git://git.debian.org/git/pkg-mysql/mariadb-10.0.git
Alternatively use Github mirror at https://github.com/ottok/mariadb-10.0.git
On later runs make sure to have latest version of sources
gbp-pull --pristine-tar --force
Build
git-buildpackage --git-pristine-tar
For a more elaborate setup with automatic build dependency installation and
multi-target chroot usage check out how http://labs.seravo.fi/~otto/mariadb-repo/build.sh
uses git-buildpackage with pbuilder.
If the build fails the easiest way to clean up before a new run is
git clean -f -d && git reset --hard
### Tip ###
Don't run the mysql-test-run test suite as part of build.
It takes a lot of time, and we will do a better test anyway in
Buildbot, running the test suite from installed .debs on a clean VM.
export DEB_BUILD_OPTIONS="nocheck"
If you want to run the build in parallel on 2 CPUs and have verbose output, use:
export DEB_BUILD_OPTIONS="parallel=2 verbose"
The options above can also be combined freely to get required behaviour.
## Importing initial sources from upstream the first fime ##
Create repository
mkdir mariadb-10.0
cd mariadb-10.0
git init
git branch upstream
git-import-orig --pristine-tar ../../upstream/mariadb-10.0.14
Fill in values prompted
What will be the source package name? [mariadb] mariadb-10.0
What is the upstream version? [10.0.14]
Checkout master into working dir and finish up manually what needs to be done
git checkout master
Eventually commit and push, build, test binaries, test packages etc..
git commit -m "Created Debian packaging using git-buildpackage for easy maintenance"
git push --all
git push --tags
## Upgrading sources from upstream ##
Upstream will publish maintenance releases at least 5 years after the major
version release, and security updates are likely to come even after that as
long as major distributions ship the version.
See table at
https://mariadb.com/kb/en/mariadb/development/mariadb-maintenance-policy/
Release notes are available at
https://mariadb.com/kb/en/mariadb/development/release-notes/
### Steps to import new upstream version ###
Download new source package
cd pkg-mariadb-10.0
uscan --verbose
Enter git repository path and apply new sources
cd mariadb-10.0
git-import-orig --pristine-tar ../mariadb-10.0.14.tar.gz
Generate new debian/changelog entry
dch -v 10.0.14-1 -D unstable
Manually merge what needs to be done
Commit and push
git commit -am "Merged with upstream 10.0.14"
git push --all; git push --all github
git push --tags; git push --tags github
Note that in above if you want to sync to Github directly you need to have
collaborator rights to the Github repo and you need to add it as a secondary
remote location with:
git remote add origin [email protected]:ottok/mariadb-10.0.git
To push to the git.debian.org repos you need to a member of the pkg-mysql team
at Alioth. It does not matter which repository you push to, eventually they are
synced with each other anyway.
### Maintaining patches ###
Test that the patches still apply by running:
export QUILT_PATCHES=debian/patches
quilt import
quilt push -a
If there are any rejects, inspect the files and update the patches.
### Maintaining debian/copyright ###
First install packages: license-reconcile devscripts cdbs
Check if licenses match
license-reconcile
Create new copyright file
licensecheck --copyright -r . -c . | /usr/lib/cdbs/licensecheck2dep5 > /tmp/copyright
..but you need to do lots of manual work to merge the new file with the old, as
licensecheck has a lot of cruft and the original copyright file already had
those cleaned up.
### Quality control ###
Run wrap-and-sort to style contents in debian/*
wrap-and-sort
Once packages are done check their quality with Lintian
lintian -EvIL +pedantic --color=always *.deb
## Uploading to Ubuntu PPA for testing ##
Make sure you have key ID set up in ~/.devscripts to avoid using -k parameter
DEBSIGN_KEYID=CEE8DA88
These are good to have as environment variables (replace values with your own)
DEBEMAIL="[email protected]"
DEBFULLNAME="Otto Kekäläinen"
export DEBEMAIL DEBFULLNAME
The run the commands to automatically change version and upload
backportpackage -u ppa:mysql-ubuntu/mariadb -d precise -r *.dsc -S ~ppa1 -y
## Uploading to Ubuntu security releases ##
See example with documented procedure:
* https://bugs.launchpad.net/ubuntu/+source/mariadb-5.5/+bug/1464895
Probably the most optimal work-flow would be to create a git branch (e.g.
ubuntu-14.04) with custom gbp.conf and maintaining it by importing upstream in
one commit, and updating changelog and other stuff, including refreshing
patches in another commits, so that it would be easy to produce a patch file
that Ubuntu security team can apply upon the mix of previous debian/ contents
from Ubuntu archive and updated others from upstream. This would allow to use
git-buildpackage to produce test builds instead of plain 'fakeroot dpkg-buildpackage'.
## Comparison to other distributions ##
For tracking security release information, finding solutions for build errors
on many architectures and for general quality control it can be useful to keep
an eye on what packagers in other distributions do:
Fedora:
* https://apps.fedoraproject.org/packages/mariadb/
* http://pkgs.fedoraproject.org/cgit/mariadb.git/
OpenSUSE:
* https://build.opensuse.org/package/show/server:database/mariadb
Arch Linux:
* https://projects.archlinux.org/svntogit/packages.git/?h=packages/mariadb
Mageia:
* http://svnweb.mageia.org/packages/cauldron/mariadb/current/
## Notes about hard to fix bugs ##
The following issues at https://qa.debian.org/bls/packages/m/mariadb-10.0.html
are due to a bug in GCC which has been reported to GCC and will become fixed
eventually:
E array-bounds /??PKGBUILDDIR??/strings/decimal.c:300 (arm64, armel, armhf, i386, mips, mipsel, powerpc, ppc64el, sparc)
E array-bounds /??PKGBUILDDIR??/strings/decimal.c:496 (arm64, armel, armhf, i386, mips, mipsel, powerpc, ppc64el, sparc)