RELEASE 3.07 KB
Newer Older
Clément OUDOT's avatar
Clément OUDOT committed
1
2
3
4
5
6
7
How to build a release for LemonLDAP::NG
========================================

The version
-----------

- The release version should be updated in the following location:
Yadd's avatar
Yadd committed
8
* changelog (add a changelog from GitLab for the target version)
Clément OUDOT's avatar
Clément OUDOT committed
9
10
* Main modules (Common.pm/Handler.pm/Portal.pm/Manager.pm)
* Makefile.PL for cross-dependencies
Clément OUDOT's avatar
Clément OUDOT committed
11
* Doxyfile
Clément OUDOT's avatar
Clément OUDOT committed
12
13

- Then update packages information with:
14
$ make clean && make cpan
Clément OUDOT's avatar
Clément OUDOT committed
15
16

- Version must also be updated in RPM and Debian build files
17
18
  - rpm/lemonldap-ng.spec: update versions and add changelog entry
  - debian/changelog: add changelog entry
Clément OUDOT's avatar
Clément OUDOT committed
19
20
21
22
23

Before release
--------------

- Update documentation:
24
$ make documentation
25

Clément OUDOT's avatar
Clément OUDOT committed
26
27
28
- Translate documentation
$ make fr-doc

Yadd's avatar
Yadd committed
29
30
31
- Update debian/changelog
  launch just `dch -r` and force save (":w" and ot ":x")

Clément OUDOT's avatar
Clément OUDOT committed
32
33
34
- Check Debian packages quality
$ cme check dpkg

35
36
37
For minor release
-----------------

Clément OUDOT's avatar
Clément OUDOT committed
38
- Go on gitlab and create a new tag: https://gitlab.ow2.org/lemonldap-ng/lemonldap-ng/tags/new
39
40
41
42

For major release
-----------------

Clément OUDOT's avatar
Clément OUDOT committed
43
- Go on gitlab and create a new branch: https://gitlab.ow2.org/lemonldap-ng/lemonldap-ng/branches/new
Clément OUDOT's avatar
Clément OUDOT committed
44

Clément OUDOT's avatar
Clément OUDOT committed
45
- Go on gitlab and create a new tag: https://gitlab.ow2.org/lemonldap-ng/lemonldap-ng/tags/new
Clément OUDOT's avatar
Clément OUDOT committed
46

47
48
49
50
- Change "latest" symlink in dokuwiki 

- Edit scripts/doc.pl in trunk to point on the new documentation path

51
52
Make the distribution
---------------------
Clément OUDOT's avatar
Clément OUDOT committed
53

54
55
- CPAN packages:
$ make clean && make cpan
Clément OUDOT's avatar
Clément OUDOT committed
56
57

- Tarball:
58
59
$ make clean && make dist

Clément OUDOT's avatar
Clément OUDOT committed
60
61
62
63
64
65
- RedHat packaging:

Create the RPM specific tarball:
$ make clean && make rpm-dist

Next steps: see rpm/README
66
67
68

- Debian packaging:

69
70
71
72
Create the debian specific tarball:
$ make clean && make debian-dist

Untar the debian archive and launch:
73
74
75
76
77
78
$ make debian-packages

Packages are in /tmp

Sign packages:
$ dpkg-sig -p --sign builder /tmp/*.deb
Clément OUDOT's avatar
Clément OUDOT committed
79
80


81
82
Upload the distribution
---------------------
Clément OUDOT's avatar
Clément OUDOT committed
83

84
85
86
87
88
89
90
91
92
93
94
- CPAN:
Upload modules tarballs (generated by make cpan)

- OW2 Forge:
Upload dist and bundles

- RPM: see rpm/REDAME

- DEB:
The DEB repository is hosted on http://lemonldap-ng.org/deb

Clément OUDOT's avatar
Clément OUDOT committed
95
96
Copy all generated files (*.deb):
$ scp *.deb lemonldapng@lemonldap-ng.org:incoming/
97
98
99
100

Then connect on the server and launch reprepro:
$ ssh lemonldapng@lemonldap-ng.org
lemonldapng@lemonldap-ng.org$ cd deb/
Clément OUDOT's avatar
Clément OUDOT committed
101
102
lemonldapng@sd-22107:~/deb$ reprepro --ask-passphrase -Vb . includedeb stable ../incoming/*VERSION*deb
lemonldapng@sd-22107:~/deb$ reprepro --ask-passphrase -Vb . includedeb 2.0 ../incoming/*VERSION*deb
103
104

See also reprepro configuration file: 'distributions'
Clément OUDOT's avatar
Clément OUDOT committed
105

Clément OUDOT's avatar
Clément OUDOT committed
106
107
108
109
110
- Docker:
Build a new image from https://github.com/LemonLDAPNG/lemonldap-ng-docker
Tag image to latest
Upload on Docker hub

Clément OUDOT's avatar
Clément OUDOT committed
111
112
113
114
Site
----

- Update links on the download page
Clément OUDOT's avatar
Clément OUDOT committed
115
- Close the milestone on Gitlab and create a new one
Clément OUDOT's avatar
Clément OUDOT committed
116
117
118
119

Spread the word
---------------

Clément OUDOT's avatar
Clément OUDOT committed
120
121
122
123
- News on OW2 projects page: https://projects.ow2.org/bin/view/lemonldap-ng/
- Twitter account / Facebook page
- IRC channel subject and Mattermost
- Mailing lists: lemonldap-ng-users / lemonldap-ng-announces
Clément OUDOT's avatar
Clément OUDOT committed
124
125
- Optional: blogs and news sites (LinuxFR, etc.)

Yadd's avatar
Yadd committed
126
127
128
129
130
131
132
After release
-------------

- Update debian/changelog
$ dch -v <New number>-1 (and write "New release")
- Update $VERSION anywhere