Skip to content

Commit

Permalink
fix: pnpm install command failure (#9)
Browse files Browse the repository at this point in the history
Co-authored-by: zhaoxiaojie <[email protected]>
  • Loading branch information
LinuxSuRen and zhaoxiaojie authored May 17, 2024
1 parent 54cf073 commit 699beb6
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 21 deletions.
35 changes: 15 additions & 20 deletions runtime/node.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"bufio"
"bytes"
"encoding/json"
"errors"
"fmt"
"log/slog"
"os"
Expand Down Expand Up @@ -139,34 +140,28 @@ func (d *Node) GenerateDockerfile(path string) ([]byte, error) {
See https://flexstack.com/docs/languages-and-frameworks/autogenerate-dockerfile`, *version, packageManager, installCMD, buildCMD, startCMD),
)

if installCMD != "" {
installCMDJSON, _ := json.Marshal(installCMD)
installCMD = string(installCMDJSON)
}

if buildCMD != "" {
buildCMDJSON, _ := json.Marshal(buildCMD)
buildCMD = string(buildCMDJSON)
}

if startCMD != "" {
startCMDJSON, _ := json.Marshal(startCMD)
startCMD = string(startCMDJSON)
}

var buf bytes.Buffer
if err := tmpl.Option("missingkey=zero").Execute(&buf, map[string]string{
"Version": *version,
"InstallCMD": installCMD,
"BuildCMD": buildCMD,
"StartCMD": startCMD,
"InstallCMD": safeCommand(installCMD),
"BuildCMD": safeCommand(buildCMD),
"StartCMD": safeCommand(startCMD),
}); err != nil {
return nil, fmt.Errorf("Failed to execute template")
return nil, errors.New("Failed to execute template")
}

return buf.Bytes(), nil
}

func safeCommand(cmd string) string {
if cmd == "" {
return ""
}

cmdJSON, _ := json.Marshal(cmd)
return strings.ReplaceAll(string(cmdJSON), `\u0026\u0026`, "&&")
}

var startScriptRe = regexp.MustCompile(`^.*?\b(ts-)?node(mon)?\b.*?(index|main|server|client)\.([cm]?[tj]s)\b`)

var nodeTemplate = strings.TrimSpace(`
Expand All @@ -177,7 +172,7 @@ FROM base AS deps
WORKDIR /app
COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* bun.lockb* ./
ARG INSTALL_CMD={{.InstallCMD}}
RUN if [ ! -z "${INSTALL_CMD}" ]; then $INSTALL_CMD; fi
RUN if [ ! -z "${INSTALL_CMD}" ]; then echo "${INSTALL_CMD}" > dep.sh; sh dep.sh; fi
FROM base AS builder
WORKDIR /app
Expand Down
2 changes: 1 addition & 1 deletion runtime/node_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ func TestNodeGenerateDockerfile(t *testing.T) {
{
name: "Node project with pnpm",
path: "../testdata/node-pnpm",
expected: []any{`ARG VERSION=16.0.0`, `ARG INSTALL_CMD="corepack enable pnpm \u0026\u0026 pnpm i --frozen-lockfile"`, `ARG BUILD_CMD="pnpm run build:prod"`, `ARG START_CMD="pnpm run start:production"`},
expected: []any{`ARG VERSION=16.0.0`, `ARG INSTALL_CMD="corepack enable pnpm && pnpm i --frozen-lockfile"`, `ARG BUILD_CMD="pnpm run build:prod"`, `ARG START_CMD="pnpm run start:production"`},
},
{
name: "Node project with yarn",
Expand Down

0 comments on commit 699beb6

Please sign in to comment.