Skip to content

Commit

Permalink
SNOW-1055755: use docker to build linux packages
Browse files Browse the repository at this point in the history
  • Loading branch information
sfc-gh-mraba committed Jul 31, 2024
1 parent 43bfe9f commit e04d465
Show file tree
Hide file tree
Showing 7 changed files with 84 additions and 1 deletion.
7 changes: 6 additions & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,12 @@ python = "3.11"
features = ["development", "packaging"]

[tool.hatch.envs.packaging.scripts]
build = ["pyinstaller --clean -y snow.spec"]
build-binaries = ["./scripts/packaging/build_binaries.sh"]
build-packages = ["./scripts/packaging/build_packages.sh"]
build-all = [
"./scripts/packaging/build_binaries.sh",
"./scripts/packaging/build_packages.sh",
]

[tool.hatch.envs.e2e]
template = "e2e"
Expand Down
10 changes: 10 additions & 0 deletions scripts/packaging/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
FROM python:3.11-bookworm

RUN apt update
RUN apt upgrade -y
RUN apt install -y ruby squashfs-tools rpm
RUN gem install fpm
RUN pip install -U pip uv hatch

WORKDIR /snowflake-cli
RUN git clone https://github.com/snowflakedb/snowflake-cli.git .
12 changes: 12 additions & 0 deletions scripts/packaging/build_binaries.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
#!/bin/env bash
set -o pipefail

VERSION=$(hatch version)

hatch -e packaging run pyinstaller \
--name=snow \
--onedir \
--clean \
--noconfirm \
--contents-directory=snowflake-cli-${VERSION} \
src/snowflake/cli/app/__main__.py
31 changes: 31 additions & 0 deletions scripts/packaging/build_packages.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
#!/bin/env bash
set -o pipefail

VERSION=$(hatch version)
THIS_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
DEB_PGK="snowflke-cli-${VERSION}.deb"
RPM_PGK="snowflke-cli-${VERSION}.rpm"

fpm \
-s dir \
-t deb \
--name snow \
--version ${VERSION} \
-p DEB_PGK \
-C ./dist/snow \
--prefix /usr/lib/snowflake/snowflake-cli \
--after-install $THIS_DIR/ubuntu/after_install.sh \
--after-remove $THIS_DIR/ubuntu/after_remove.sh \
--force

fpm \
-s dir \
-t rpm \
--name snow \
--version ${VERSION} \
-p RPM_PGK \
-C ./dist/snow \
--prefix /usr/lib/snowflake/snowflake-cli \
--after-install $THIS_DIR/ubuntu/after_install.sh \
--after-remove $THIS_DIR/ubuntu/after_remove.sh \
--force
5 changes: 5 additions & 0 deletions scripts/packaging/docker-compose.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
services:
package-builder:
build: .
volumes:
- ../../:/snowflake-cli
9 changes: 9 additions & 0 deletions scripts/packaging/ubuntu/after_install.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#!/bin/bash -e
#
# Snowcd after install script
set -o pipefail

SNOWFLAKE_CLI_LINK=/usr/local/bin/snow
SNOWFLAKE_CLI_BIN=/usr/lib/snowflake/snowflake-cli/snow
rm -f ${SNOWFLAKE_CLI_LINK}
ln -s ${SNOWFLAKE_CLI_BIN} ${SNOWFLAKE_CLI_LINK}
11 changes: 11 additions & 0 deletions scripts/packaging/ubuntu/after_remove.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
#!/bin/bash -e
#
# Snowcd after remove script
#
set -o pipefail

SNOWFLAKE_CLI_LINK=/usr/local/bin/snow
if [[ -L "${SNOWFLAKE_CLI_LINK}" ]]; then
# delete only if it is symlink
rm -f "${SNOWFLAKE_CLI_LINK}"
fi

0 comments on commit e04d465

Please sign in to comment.