Skip to content

Commit

Permalink
ICU-22606 Create full release from CI - update docs
Browse files Browse the repository at this point in the history
  • Loading branch information
mihnita committed Sep 30, 2024
1 parent bef5b77 commit f16f18c
Show file tree
Hide file tree
Showing 2 changed files with 99 additions and 1 deletion.
15 changes: 14 additions & 1 deletion docs/processes/release/tasks/publish/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -241,16 +241,22 @@ Download Directories are located at, for example,
corresponding to <http://download.icu-project.org/ex/files/icu4c/4.4.2/>
Look at previous releases for an example.

### Java Source/Bin:
### Java Source/Bin

**Post 76.1 see [Publish - Version 76.1](release.md)**

Follow instructions here: [Building ICU4J Release Files](../release-build.md)

### C source/binary:

**Post 76.1 see [Publish - Version 76.1](release.md)**

<span style="background:yellow">***WORK IN PROGRESS***</a>

#### Source and Linux Binaries:

**Post 76.1 see [Publish - Version 76.1](release.md)**

Important: this step works with Unix make + docker.

First, install *docker* and *docker-compose. D*o not proceed until *docker run
Expand Down Expand Up @@ -285,6 +291,9 @@ run \`make dist\`.

#### Windows Binary:

**Post 76.1 see [Publish - Version 76.1](release.md)** \
That new flow overlaps with _"Using the output from the build bots"_ below.

* Manual process:
* Build with MSVC x64 Release. (See the ICU
[readme.html](https://github.com/unicode-org/icu/main/blob/icu4c/readme.html)
Expand Down Expand Up @@ -345,6 +354,8 @@ run \`make dist\`.
#### Output of icuexportdata:
**Post 76.1 see [Publish - Version 76.1](release.md)**
This step publishes pre-processed Unicode property data, which may be ingested by downstream clients such as ICU4X.
* Using the output from the build bots:
Expand All @@ -354,6 +365,8 @@ This step publishes pre-processed Unicode property data, which may be ingested b
### Signing archives and creating checksums:
**Post 76.1 see [Publish - Version 76.1](release.md)**
#### Step 0. PGP keys:
Use your own personal PGP key. Make sure that at least one other member of the
Expand Down
85 changes: 85 additions & 0 deletions docs/processes/release/tasks/publish/release.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
---
layout: default
title: Publish - Version 76.1 - WIP
parent: Release & Milestone Tasks
grand_parent: Contributors
nav_order: 90
---

<!--
© 2024 and later: Unicode, Inc. and others.
License & terms of use: http://www.unicode.org/copyright.html
-->

# Publish - Version 76.1 - WIP
{: .no_toc }

## Contents
{: .no_toc .text-delta }

---

## Most artifacts are now built in the GitHub CI. Work in Progress!!!

Many of the tasks that used to be done before "by hand" are now at least
partially done by GitHub Actions.

The release requires (for now) triggering the actions "by hand".

First go to [Github - unicode-org/icu](https://github.com/unicode-org/icu).

Create a release, give it a tag (something like `release-76` or `release-74-2`) \
Make sure the release is **DRAFT**.

That tag will need to be passed to several of the actions below.

Go to [Github - unicode-org/icu](https://github.com/unicode-org/icu) -- Actions
and select the action to run from the left side.

Select an action and (from the right side) select "Run workflow".

Some actions will have an "Run the tests." option. \
**KEEP IT ON!** It is there for development, but you MUST run the tests for release.

Most will have a "Release tag to upload to." option. \
Here you should use the release tag.

1. **GHA ICU4C** \
This step creates the binaries BUT IT WILL NOT ADD THEM TO RELEASE (yet). \
You will need to downloaded the artifacts at the end of the run, unpack,
check the names, and upload to the release (for now). \
This action creates:
* The Windows binaries (`icu4c-{icuver}-Win32-MSVC20??.zip`,
`icu4c-{icuver}-Win64-MSVC20??.zip`, `icu4c-{icuver}-WinARM64-MSVC20??.zip`)
* The packaged data for ICU4X (`icuexportdata_tag-goes-here.zip`) \
**WARNING:** this might be a zip inside a zip. To unpack and rename. \
The proper name is `icuexportdata_release-{icuver}.zip`

1. **Release - ICU4C artifacts on Fedora** (`release-icu4c-fedora.yml`) \
This will create and add to release:
* `icu4c-{icuver}-Fedora_Linux??-x64.tgz`.

1. **Release - ICU4C artifacts on Ubuntu** (`release-icu4c-ubuntu.yml`) \
This will create and add to release:
* The `icu4c-{icuver}-Ubuntu??.04-x64.tgz` file
* The icu4c data files (`icu4c-{icuver}-data.zip`,
`icu4c-{icuver}-data-bin-b.zip`, `icu4c-{icuver}-data-bin-l.zip`)
* The icu4c source archives (`icu4c-{icuver}-src.tgz` and `icu4c-{icuver}-src.zip`)
* The ICU4C documentation (`icu4c-76_1-docs.zip`) \
**WARNING:** this is also the one to be published (unpacked) for web access

1. **Release - ICU4J publish to Maven Central** (`release-icu4j-maven.yml`) \
This will create, publish to Maven Cental (using Sonatype), and add to release:
* All the official Maven artifacts, including sources and javadoc. \
The Maven Central artifacts have checksums and are digitally signed. \
Someone with access to Sonatype Nexus should still login there and authorize
the promotion to Maven Central.
* The unified Java documentation, (`icu4j-76.1-fulljavadoc.jar`) \
**WARNING:** this is also the one to be published (unpacked) for web access

1. **Release - Create checksums and GPG sign** (`release-check-sign.yml`) \
THIS SHOULD BE THE LAST ACTION YOU RUN. \
After all the artifacts from the previous steps are posted to the release. \
The action will download all the artifacts from release,
create checksum files (`SHASUM512.txt` and `*.md5`),
and digital signature files (`*.asc`)

0 comments on commit f16f18c

Please sign in to comment.