mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-03-03 15:02:35 +02:00
fix (npmExecuteScripts) allow npm pack before npm publish (#3455)
* adding config to piperNpmr * scope in cli * adding scope to repo url and npmrc * publish to scoped * removing scope * changing scope position * adding scope to userconfig * adding registry= * pack and then tar * not removing tmp folder * adding flag * pack before publish * adding log * debug * debug with change directory * publishing created tar ball * debug * üath * adding main npmrc * renaming old npmrc file * error renaming old npmrc file * renaming err * correcting npmrc file path * renaming file back to original * current working directory * renaming the npmrc file * avoiding change directory * with current working dir * adding dot * renaming npmrc and defer removal * rename files * Update pkg/npm/publish.go * Update pkg/npm/publish.go Co-authored-by: anilkeshav27 <you@example.com> Co-authored-by: Oliver Nocon <33484802+OliverNocon@users.noreply.github.com>
This commit is contained in:
parent
4e0684cf78
commit
1a96d7a67e
@ -73,7 +73,7 @@ func runNpmExecuteScripts(npmExecutor npm.Executor, config *npmExecuteScriptsOpt
|
||||
return err
|
||||
}
|
||||
|
||||
err = npmExecutor.PublishAllPackages(packageJSONFiles, config.RepositoryURL, config.RepositoryUsername, config.RepositoryPassword)
|
||||
err = npmExecutor.PublishAllPackages(packageJSONFiles, config.RepositoryURL, config.RepositoryUsername, config.RepositoryPassword, config.PackBeforePublish)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
@ -31,6 +31,7 @@ type npmExecuteScriptsOptions struct {
|
||||
RepositoryPassword string `json:"repositoryPassword,omitempty"`
|
||||
RepositoryUsername string `json:"repositoryUsername,omitempty"`
|
||||
BuildSettingsInfo string `json:"buildSettingsInfo,omitempty"`
|
||||
PackBeforePublish bool `json:"packBeforePublish,omitempty"`
|
||||
}
|
||||
|
||||
type npmExecuteScriptsCommonPipelineEnvironment struct {
|
||||
@ -167,6 +168,7 @@ func addNpmExecuteScriptsFlags(cmd *cobra.Command, stepConfig *npmExecuteScripts
|
||||
cmd.Flags().StringVar(&stepConfig.RepositoryPassword, "repositoryPassword", os.Getenv("PIPER_repositoryPassword"), "Password for the repository to which the project artifacts should be published.")
|
||||
cmd.Flags().StringVar(&stepConfig.RepositoryUsername, "repositoryUsername", os.Getenv("PIPER_repositoryUsername"), "Username for the repository to which the project artifacts should be published.")
|
||||
cmd.Flags().StringVar(&stepConfig.BuildSettingsInfo, "buildSettingsInfo", os.Getenv("PIPER_buildSettingsInfo"), "build settings info is typically filled by the step automatically to create information about the build settings that were used during the npm build . This information is typically used for compliance related processes.")
|
||||
cmd.Flags().BoolVar(&stepConfig.PackBeforePublish, "packBeforePublish", false, "used for pack")
|
||||
|
||||
}
|
||||
|
||||
@ -321,6 +323,15 @@ func npmExecuteScriptsMetadata() config.StepData {
|
||||
Aliases: []config.Alias{},
|
||||
Default: os.Getenv("PIPER_buildSettingsInfo"),
|
||||
},
|
||||
{
|
||||
Name: "packBeforePublish",
|
||||
ResourceRef: []config.ResourceReference{},
|
||||
Scope: []string{"STEPS", "STAGES", "PARAMETERS"},
|
||||
Type: "bool",
|
||||
Mandatory: false,
|
||||
Aliases: []config.Alias{},
|
||||
Default: false,
|
||||
},
|
||||
},
|
||||
},
|
||||
Containers: []config.Container{
|
||||
|
@ -122,6 +122,6 @@ func (n *NpmExecutorMock) CreateBOM(packageJSONFiles []string) error {
|
||||
}
|
||||
|
||||
// CreateBOM mock implementation
|
||||
func (n *NpmExecutorMock) PublishAllPackages(packageJSONFiles []string, registry, username, password string) error {
|
||||
func (n *NpmExecutorMock) PublishAllPackages(packageJSONFiles []string, registry, username, password string, packBeforePublish bool) error {
|
||||
return nil
|
||||
}
|
||||
|
@ -26,7 +26,7 @@ type Executor interface {
|
||||
FindPackageJSONFilesWithScript(packageJSONFiles []string, script string) ([]string, error)
|
||||
RunScriptsInAllPackages(runScripts []string, runOptions []string, scriptOptions []string, virtualFrameBuffer bool, excludeList []string, packagesList []string) error
|
||||
InstallAllDependencies(packageJSONFiles []string) error
|
||||
PublishAllPackages(packageJSONFiles []string, registry, username, password string) error
|
||||
PublishAllPackages(packageJSONFiles []string, registry, username, password string, packBeforePublish bool) error
|
||||
SetNpmRegistries() error
|
||||
CreateBOM(packageJSONFiles []string) error
|
||||
}
|
||||
|
@ -2,6 +2,8 @@ package npm
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"io/ioutil"
|
||||
"os"
|
||||
"path/filepath"
|
||||
|
||||
"github.com/pkg/errors"
|
||||
@ -12,7 +14,7 @@ import (
|
||||
)
|
||||
|
||||
// PublishAllPackages executes npm publish for all package.json files defined in packageJSONFiles list
|
||||
func (exec *Execute) PublishAllPackages(packageJSONFiles []string, registry, username, password string) error {
|
||||
func (exec *Execute) PublishAllPackages(packageJSONFiles []string, registry, username, password string, packBeforePublish bool) error {
|
||||
for _, packageJSON := range packageJSONFiles {
|
||||
fileExists, err := exec.Utils.FileExists(packageJSON)
|
||||
if err != nil {
|
||||
@ -22,7 +24,7 @@ func (exec *Execute) PublishAllPackages(packageJSONFiles []string, registry, use
|
||||
return fmt.Errorf("package.json file '%s' not found: %w", packageJSON, err)
|
||||
}
|
||||
|
||||
err = exec.publish(packageJSON, registry, username, password)
|
||||
err = exec.publish(packageJSON, registry, username, password, packBeforePublish)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -31,7 +33,7 @@ func (exec *Execute) PublishAllPackages(packageJSONFiles []string, registry, use
|
||||
}
|
||||
|
||||
// publish executes npm publish for package.json
|
||||
func (exec *Execute) publish(packageJSON, registry, username, password string) error {
|
||||
func (exec *Execute) publish(packageJSON, registry, username, password string, packBeforePublish bool) error {
|
||||
execRunner := exec.Utils.GetExecRunner()
|
||||
|
||||
npmignore := NewNPMIgnore(filepath.Dir(packageJSON))
|
||||
@ -91,9 +93,63 @@ func (exec *Execute) publish(packageJSON, registry, username, password string) e
|
||||
log.Entry().Debug("no registry provided")
|
||||
}
|
||||
|
||||
err := execRunner.RunExecutable("npm", "publish", "--userconfig", npmrc.filepath, "--registry", registry)
|
||||
if err != nil {
|
||||
return err
|
||||
if packBeforePublish {
|
||||
tmpDirectory := getTempDirForNpmTarBall()
|
||||
defer os.RemoveAll(tmpDirectory)
|
||||
|
||||
err := execRunner.RunExecutable("npm", "pack", "--pack-destination", tmpDirectory)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
_, err = FileUtils.Copy(npmrc.filepath, filepath.Join(tmpDirectory, ".piperNpmrc"))
|
||||
if err != nil {
|
||||
return fmt.Errorf("error copying piperNpmrc file from %v to %v with error: %w",
|
||||
npmrc.filepath, filepath.Join(tmpDirectory, ".piperNpmrc"), err)
|
||||
}
|
||||
|
||||
tarballFileName := ""
|
||||
err = filepath.Walk(tmpDirectory, func(path string, info os.FileInfo, err error) error {
|
||||
if filepath.Ext(path) == ".tgz" {
|
||||
tarballFileName = "." + string(filepath.Separator) + path
|
||||
log.Entry().Debugf("found tarball file at %v", tarballFileName)
|
||||
}
|
||||
return nil
|
||||
})
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
// rename the .npmrc file since it interferes with publish
|
||||
err = os.Rename(filepath.Join(filepath.Dir(packageJSON), ".npmrc"), filepath.Join(filepath.Dir(packageJSON), ".tmpNpmrc"))
|
||||
if err != nil {
|
||||
return fmt.Errorf("error when renaming current .npmrc file : %w", err)
|
||||
}
|
||||
|
||||
err = execRunner.RunExecutable("npm", "publish", "--tarball", tarballFileName, "--userconfig", filepath.Join(tmpDirectory, ".piperNpmrc"), "--registry", registry)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
// undo the renaming ot the .npmrc to keep the workspace like before
|
||||
err = os.Rename(filepath.Join(filepath.Dir(packageJSON), ".tmpNpmrc"), filepath.Join(filepath.Dir(packageJSON), ".npmrc"))
|
||||
if err != nil {
|
||||
log.Entry().Warnf("unable to rename the .npmrc file : %v", err)
|
||||
}
|
||||
} else {
|
||||
err := execRunner.RunExecutable("npm", "publish", "--userconfig", npmrc.filepath, "--registry", registry)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func getTempDirForNpmTarBall() string {
|
||||
tmpFolder, err := ioutil.TempDir(".", "temp-")
|
||||
if err != nil {
|
||||
log.Entry().WithError(err).WithField("path", tmpFolder).Debug("Creating temp directory failed")
|
||||
}
|
||||
return tmpFolder
|
||||
}
|
||||
|
@ -126,6 +126,14 @@ spec:
|
||||
resourceRef:
|
||||
- name: commonPipelineEnvironment
|
||||
param: custom/buildSettingsInfo
|
||||
- name: packBeforePublish
|
||||
type: bool
|
||||
default: false
|
||||
description: used for pack
|
||||
scope:
|
||||
- STEPS
|
||||
- STAGES
|
||||
- PARAMETERS
|
||||
outputs:
|
||||
resources:
|
||||
- name: commonPipelineEnvironment
|
||||
|
Loading…
x
Reference in New Issue
Block a user