fix: stabilize install smoke against clawdbot installer
This commit is contained in:
2
.github/workflows/install-smoke.yml
vendored
2
.github/workflows/install-smoke.yml
vendored
@@ -37,5 +37,5 @@ jobs:
|
|||||||
CLAWDBOT_NO_ONBOARD: "1"
|
CLAWDBOT_NO_ONBOARD: "1"
|
||||||
CLAWDBOT_INSTALL_SMOKE_SKIP_CLI: "1"
|
CLAWDBOT_INSTALL_SMOKE_SKIP_CLI: "1"
|
||||||
CLAWDBOT_INSTALL_SMOKE_SKIP_NONROOT: ${{ github.event_name == 'pull_request' && '1' || '0' }}
|
CLAWDBOT_INSTALL_SMOKE_SKIP_NONROOT: ${{ github.event_name == 'pull_request' && '1' || '0' }}
|
||||||
CLAWDBOT_INSTALL_SMOKE_PREVIOUS: "2026.1.11-4"
|
CLAWDBOT_INSTALL_SMOKE_SKIP_PREVIOUS: "1"
|
||||||
run: pnpm test:install:smoke
|
run: pnpm test:install:smoke
|
||||||
|
|||||||
@@ -2,6 +2,16 @@
|
|||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
INSTALL_URL="${CLAWDBOT_INSTALL_URL:-https://molt.bot/install.sh}"
|
INSTALL_URL="${CLAWDBOT_INSTALL_URL:-https://molt.bot/install.sh}"
|
||||||
|
DEFAULT_PACKAGE="moltbot"
|
||||||
|
if [[ -z "${CLAWDBOT_INSTALL_PACKAGE:-}" && "$INSTALL_URL" == *"clawd.bot"* ]]; then
|
||||||
|
DEFAULT_PACKAGE="clawdbot"
|
||||||
|
fi
|
||||||
|
PACKAGE_NAME="${CLAWDBOT_INSTALL_PACKAGE:-$DEFAULT_PACKAGE}"
|
||||||
|
if [[ "$PACKAGE_NAME" == "moltbot" ]]; then
|
||||||
|
ALT_PACKAGE_NAME="clawdbot"
|
||||||
|
else
|
||||||
|
ALT_PACKAGE_NAME="moltbot"
|
||||||
|
fi
|
||||||
|
|
||||||
echo "==> Pre-flight: ensure git absent"
|
echo "==> Pre-flight: ensure git absent"
|
||||||
if command -v git >/dev/null; then
|
if command -v git >/dev/null; then
|
||||||
@@ -18,26 +28,39 @@ export PATH="$HOME/.npm-global/bin:$PATH"
|
|||||||
echo "==> Verify git installed"
|
echo "==> Verify git installed"
|
||||||
command -v git >/dev/null
|
command -v git >/dev/null
|
||||||
|
|
||||||
echo "==> Verify moltbot installed"
|
|
||||||
EXPECTED_VERSION="${CLAWDBOT_INSTALL_EXPECT_VERSION:-}"
|
EXPECTED_VERSION="${CLAWDBOT_INSTALL_EXPECT_VERSION:-}"
|
||||||
if [[ -n "$EXPECTED_VERSION" ]]; then
|
if [[ -n "$EXPECTED_VERSION" ]]; then
|
||||||
LATEST_VERSION="$EXPECTED_VERSION"
|
LATEST_VERSION="$EXPECTED_VERSION"
|
||||||
else
|
else
|
||||||
LATEST_VERSION="$(npm view moltbot version)"
|
LATEST_VERSION="$(npm view "$PACKAGE_NAME" version)"
|
||||||
fi
|
fi
|
||||||
CMD_PATH="$(command -v moltbot || true)"
|
CLI_NAME="$PACKAGE_NAME"
|
||||||
if [[ -z "$CMD_PATH" && -x "$HOME/.npm-global/bin/moltbot" ]]; then
|
CMD_PATH="$(command -v "$CLI_NAME" || true)"
|
||||||
CMD_PATH="$HOME/.npm-global/bin/moltbot"
|
if [[ -z "$CMD_PATH" ]]; then
|
||||||
|
CLI_NAME="$ALT_PACKAGE_NAME"
|
||||||
|
CMD_PATH="$(command -v "$CLI_NAME" || true)"
|
||||||
|
fi
|
||||||
|
if [[ -z "$CMD_PATH" && -x "$HOME/.npm-global/bin/$PACKAGE_NAME" ]]; then
|
||||||
|
CLI_NAME="$PACKAGE_NAME"
|
||||||
|
CMD_PATH="$HOME/.npm-global/bin/$PACKAGE_NAME"
|
||||||
|
fi
|
||||||
|
if [[ -z "$CMD_PATH" && -x "$HOME/.npm-global/bin/$ALT_PACKAGE_NAME" ]]; then
|
||||||
|
CLI_NAME="$ALT_PACKAGE_NAME"
|
||||||
|
CMD_PATH="$HOME/.npm-global/bin/$ALT_PACKAGE_NAME"
|
||||||
fi
|
fi
|
||||||
if [[ -z "$CMD_PATH" ]]; then
|
if [[ -z "$CMD_PATH" ]]; then
|
||||||
echo "moltbot not on PATH" >&2
|
echo "Neither $PACKAGE_NAME nor $ALT_PACKAGE_NAME is on PATH" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
if [[ -z "$EXPECTED_VERSION" && "$CLI_NAME" != "$PACKAGE_NAME" ]]; then
|
||||||
|
LATEST_VERSION="$(npm view "$CLI_NAME" version)"
|
||||||
|
fi
|
||||||
|
echo "==> Verify CLI installed: $CLI_NAME"
|
||||||
INSTALLED_VERSION="$("$CMD_PATH" --version 2>/dev/null | head -n 1 | tr -d '\r')"
|
INSTALLED_VERSION="$("$CMD_PATH" --version 2>/dev/null | head -n 1 | tr -d '\r')"
|
||||||
|
|
||||||
echo "installed=$INSTALLED_VERSION expected=$LATEST_VERSION"
|
echo "cli=$CLI_NAME installed=$INSTALLED_VERSION expected=$LATEST_VERSION"
|
||||||
if [[ "$INSTALLED_VERSION" != "$LATEST_VERSION" ]]; then
|
if [[ "$INSTALLED_VERSION" != "$LATEST_VERSION" ]]; then
|
||||||
echo "ERROR: expected moltbot@$LATEST_VERSION, got @$INSTALLED_VERSION" >&2
|
echo "ERROR: expected ${CLI_NAME}@${LATEST_VERSION}, got ${CLI_NAME}@${INSTALLED_VERSION}" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
@@ -4,15 +4,26 @@ set -euo pipefail
|
|||||||
INSTALL_URL="${CLAWDBOT_INSTALL_URL:-https://molt.bot/install.sh}"
|
INSTALL_URL="${CLAWDBOT_INSTALL_URL:-https://molt.bot/install.sh}"
|
||||||
SMOKE_PREVIOUS_VERSION="${CLAWDBOT_INSTALL_SMOKE_PREVIOUS:-}"
|
SMOKE_PREVIOUS_VERSION="${CLAWDBOT_INSTALL_SMOKE_PREVIOUS:-}"
|
||||||
SKIP_PREVIOUS="${CLAWDBOT_INSTALL_SMOKE_SKIP_PREVIOUS:-0}"
|
SKIP_PREVIOUS="${CLAWDBOT_INSTALL_SMOKE_SKIP_PREVIOUS:-0}"
|
||||||
|
DEFAULT_PACKAGE="moltbot"
|
||||||
|
if [[ -z "${CLAWDBOT_INSTALL_PACKAGE:-}" && "$INSTALL_URL" == *"clawd.bot"* ]]; then
|
||||||
|
DEFAULT_PACKAGE="clawdbot"
|
||||||
|
fi
|
||||||
|
PACKAGE_NAME="${CLAWDBOT_INSTALL_PACKAGE:-$DEFAULT_PACKAGE}"
|
||||||
|
if [[ "$PACKAGE_NAME" == "moltbot" ]]; then
|
||||||
|
ALT_PACKAGE_NAME="clawdbot"
|
||||||
|
else
|
||||||
|
ALT_PACKAGE_NAME="moltbot"
|
||||||
|
fi
|
||||||
|
|
||||||
echo "==> Resolve npm versions"
|
echo "==> Resolve npm versions"
|
||||||
|
LATEST_VERSION="$(npm view "$PACKAGE_NAME" version)"
|
||||||
if [[ -n "$SMOKE_PREVIOUS_VERSION" ]]; then
|
if [[ -n "$SMOKE_PREVIOUS_VERSION" ]]; then
|
||||||
LATEST_VERSION="$(npm view moltbot version)"
|
|
||||||
PREVIOUS_VERSION="$SMOKE_PREVIOUS_VERSION"
|
PREVIOUS_VERSION="$SMOKE_PREVIOUS_VERSION"
|
||||||
else
|
else
|
||||||
VERSIONS_JSON="$(npm view moltbot versions --json)"
|
VERSIONS_JSON="$(npm view "$PACKAGE_NAME" versions --json)"
|
||||||
versions_line="$(node - <<'NODE'
|
PREVIOUS_VERSION="$(VERSIONS_JSON="$VERSIONS_JSON" LATEST_VERSION="$LATEST_VERSION" node - <<'NODE'
|
||||||
const raw = process.env.VERSIONS_JSON || "[]";
|
const raw = process.env.VERSIONS_JSON || "[]";
|
||||||
|
const latest = process.env.LATEST_VERSION || "";
|
||||||
let versions;
|
let versions;
|
||||||
try {
|
try {
|
||||||
versions = JSON.parse(raw);
|
versions = JSON.parse(raw);
|
||||||
@@ -25,41 +36,52 @@ if (!Array.isArray(versions)) {
|
|||||||
if (versions.length === 0) {
|
if (versions.length === 0) {
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
}
|
}
|
||||||
const latest = versions[versions.length - 1];
|
const latestIndex = latest ? versions.lastIndexOf(latest) : -1;
|
||||||
const previous = versions.length >= 2 ? versions[versions.length - 2] : latest;
|
if (latestIndex > 0) {
|
||||||
process.stdout.write(`${latest} ${previous}`);
|
process.stdout.write(String(versions[latestIndex - 1]));
|
||||||
|
process.exit(0);
|
||||||
|
}
|
||||||
|
process.stdout.write(String(latest || versions[versions.length - 1]));
|
||||||
NODE
|
NODE
|
||||||
)"
|
)"
|
||||||
LATEST_VERSION="${versions_line%% *}"
|
|
||||||
PREVIOUS_VERSION="${versions_line#* }"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -n "${CLAWDBOT_INSTALL_LATEST_OUT:-}" ]]; then
|
echo "package=$PACKAGE_NAME latest=$LATEST_VERSION previous=$PREVIOUS_VERSION"
|
||||||
printf "%s" "$LATEST_VERSION" > "$CLAWDBOT_INSTALL_LATEST_OUT"
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "latest=$LATEST_VERSION previous=$PREVIOUS_VERSION"
|
|
||||||
|
|
||||||
if [[ "$SKIP_PREVIOUS" == "1" ]]; then
|
if [[ "$SKIP_PREVIOUS" == "1" ]]; then
|
||||||
echo "==> Skip preinstall previous (CLAWDBOT_INSTALL_SMOKE_SKIP_PREVIOUS=1)"
|
echo "==> Skip preinstall previous (CLAWDBOT_INSTALL_SMOKE_SKIP_PREVIOUS=1)"
|
||||||
else
|
else
|
||||||
echo "==> Preinstall previous (forces installer upgrade path)"
|
echo "==> Preinstall previous (forces installer upgrade path)"
|
||||||
npm install -g "moltbot@${PREVIOUS_VERSION}"
|
npm install -g "${PACKAGE_NAME}@${PREVIOUS_VERSION}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "==> Run official installer one-liner"
|
echo "==> Run official installer one-liner"
|
||||||
curl -fsSL "$INSTALL_URL" | bash
|
curl -fsSL "$INSTALL_URL" | bash
|
||||||
|
|
||||||
echo "==> Verify installed version"
|
echo "==> Verify installed version"
|
||||||
INSTALLED_VERSION="$(moltbot --version 2>/dev/null | head -n 1 | tr -d '\r')"
|
CLI_NAME="$PACKAGE_NAME"
|
||||||
echo "installed=$INSTALLED_VERSION expected=$LATEST_VERSION"
|
if ! command -v "$CLI_NAME" >/dev/null 2>&1; then
|
||||||
|
if command -v "$ALT_PACKAGE_NAME" >/dev/null 2>&1; then
|
||||||
|
CLI_NAME="$ALT_PACKAGE_NAME"
|
||||||
|
LATEST_VERSION="$(npm view "$CLI_NAME" version)"
|
||||||
|
echo "==> Detected alternate CLI: $CLI_NAME"
|
||||||
|
else
|
||||||
|
echo "ERROR: neither $PACKAGE_NAME nor $ALT_PACKAGE_NAME is on PATH" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [[ -n "${CLAWDBOT_INSTALL_LATEST_OUT:-}" ]]; then
|
||||||
|
printf "%s" "$LATEST_VERSION" > "$CLAWDBOT_INSTALL_LATEST_OUT"
|
||||||
|
fi
|
||||||
|
INSTALLED_VERSION="$("$CLI_NAME" --version 2>/dev/null | head -n 1 | tr -d '\r')"
|
||||||
|
echo "cli=$CLI_NAME installed=$INSTALLED_VERSION expected=$LATEST_VERSION"
|
||||||
|
|
||||||
if [[ "$INSTALLED_VERSION" != "$LATEST_VERSION" ]]; then
|
if [[ "$INSTALLED_VERSION" != "$LATEST_VERSION" ]]; then
|
||||||
echo "ERROR: expected moltbot@$LATEST_VERSION, got moltbot@$INSTALLED_VERSION" >&2
|
echo "ERROR: expected ${CLI_NAME}@${LATEST_VERSION}, got ${CLI_NAME}@${INSTALLED_VERSION}" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "==> Sanity: CLI runs"
|
echo "==> Sanity: CLI runs"
|
||||||
moltbot --help >/dev/null
|
"$CLI_NAME" --help >/dev/null
|
||||||
|
|
||||||
echo "OK"
|
echo "OK"
|
||||||
|
|||||||
Reference in New Issue
Block a user