RELEASE 3.09 KB
Newer Older
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:
8
* changelog (add a changelog from JIRA for the target version)
9 10
* Main modules (Common.pm/Handler.pm/Portal.pm/Manager.pm)
* Makefile.PL for cross-dependencies
11
* Doxyfile
12 13

- Then update packages information with:
14
$ make clean && make cpan
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
19 20 21 22 23

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

- Update documentation:
24
$ make documentation
25

26 27 28
- Translate documentation
$ make fr-doc

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

32 33 34
For minor release
-----------------

Clément OUDOT's avatar
Clément OUDOT committed
35
- Tag the version on SVN from the branch:
36
$ svn cp branches/lemonldap-ng_version_VERSION-bugfixes tags/lemonldap-ng_version_VERSION
37 38 39 40

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

Clément OUDOT's avatar
Clément OUDOT committed
41
- Create a branch on SVN from the trunk:
42
$ svn cp trunk branches/lemonldap-ng_version_VERSION-bugfixes
43

44 45
- Tag the version on SVN from the branch:
$ svn cp branches/lemonldap-ng_version_VERSION-bugfixes tags/lemonldap-ng_version_VERSION
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
---------------------
53

54 55
- CPAN packages:
$ make clean && make cpan
56 57

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

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
79 80


81 82
Upload the distribution
---------------------
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'
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

111 112 113 114 115 116 117 118 119
Site
----

- Update links on the download page
- Close the version on JIRA and create a new one

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
124 125
- Optional: blogs and news sites (LinuxFR, etc.)

Xavier Guimard's avatar
Xavier Guimard 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