status-desktop/ci
Jakub Sokołowski 4b2f2c32ad
ci: separate buckets for mobile and desktop builds
Possible fix for slow upload speeds and failures caused by most probably
hitting per-bucket rate limits of DigitalOcean:

>- 500 total operations per second to any individual bucket.
>- 300 combined PUT, POST, COPY, DELETE, and LIST operations per second
>  to any individual Space. We may further limit LIST operations if
>  necessary under periods of high load.

https://docs.digitalocean.com/products/spaces/details/limits/#rate-limits

Depends on: https://github.com/status-im/status-jenkins-lib/pull/52

Signed-off-by: Jakub Sokołowski <jakub@status.im>
2022-11-22 17:32:53 +01:00
..
cpp fix(CPP): fix linux compiling issues 2022-08-23 19:38:23 +02:00
mailserver chore: setup a mailserver as part of UI tests run in CI 2022-10-03 16:31:23 -04:00
Dockerfile chore: update go version in dockerfile 2022-08-03 09:40:47 -04:00
Jenkinsfile ci: add a combined Jenkinsfile for releases 2021-04-14 15:36:00 -04:00
Jenkinsfile.combined ci: separate buckets for mobile and desktop builds 2022-11-22 17:32:53 +01:00
Jenkinsfile.imports ci: separate buckets for mobile and desktop builds 2022-11-22 17:32:53 +01:00
Jenkinsfile.linux ci: separate buckets for mobile and desktop builds 2022-11-22 17:32:53 +01:00
Jenkinsfile.linux-cpp ci: separate buckets for mobile and desktop builds 2022-11-22 17:32:53 +01:00
Jenkinsfile.macos ci: separate buckets for mobile and desktop builds 2022-11-22 17:32:53 +01:00
Jenkinsfile.macos-cpp.todo ci: separate buckets for mobile and desktop builds 2022-11-22 17:32:53 +01:00
Jenkinsfile.uitests ci: separate buckets for mobile and desktop builds 2022-11-22 17:32:53 +01:00
Jenkinsfile.windows ci: separate buckets for mobile and desktop builds 2022-11-22 17:32:53 +01:00
Jenkinsfile.windows-cpp.todo ci: separate buckets for mobile and desktop builds 2022-11-22 17:32:53 +01:00
README.md add Jenkinsfiles and Dockerfile for CI 2020-07-01 22:06:37 +02:00

README.md

Description

These Jenkinsfiles are used to run CI jobs in Jenkins. You can find them here: https://ci.status.im/job/nim-status-client/

Builds

Linux

In order to build the Linux version of the application we use a modified a12e/docker-qt:5.14-gcc_64 Docker image with the addition of Git and Golang.

The image is built with Dockerfile using:

docker build -t statusteam/nim-status-client-build:latest .

And pushed to: https://hub.docker.com/r/statusteam/nim-status-client-build

MacOS

The MacOS builds are run on MacOS hosts and expect Command Line Toold and XCode to be installed, as well as QT being available under /usr/local/qt.

It also expects the presence of the following credentials:

  • macos-keychain-identity - ID of used signing certificate.
  • macos-keychain-pass - Password to unlock the keychain.
  • macos-keychain-file - Keychain file with the MacOS signing certificate.

You can read about how to create such a keychain here.