Skip to content
This repository has been archived by the owner on Apr 12, 2024. It is now read-only.

Commit

Permalink
Only reports may be collected to ARTIFACTS dir (#36)
Browse files Browse the repository at this point in the history
  • Loading branch information
cardil authored Oct 25, 2022
1 parent 685c106 commit 2a87471
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 11 deletions.
8 changes: 7 additions & 1 deletion pkg/dotenv/loader.go
Original file line number Diff line number Diff line change
@@ -1,10 +1,16 @@
package dotenv

import (
"os"

"github.com/joho/godotenv"
)

// Load the .env file.
func Load() error {
return godotenv.Load()
err := godotenv.Load()
if os.IsNotExist(err) {
return nil
}
return err
}
43 changes: 36 additions & 7 deletions pkg/files/dirs.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,28 +3,57 @@ package files
import (
"os"
"path"
"strings"
"sync"

"github.com/magefile/mage/mg"
"github.com/wavesoftware/go-ensure"
"github.com/wavesoftware/go-magetasks/config"
"github.com/wavesoftware/go-magetasks/pkg/dotenv"
"github.com/wavesoftware/go-magetasks/pkg/output"
"k8s.io/apimachinery/pkg/util/rand"
)

const randomDirLength = 12

var (
randomDir = "mage-build-" + rand.String(randomDirLength)
buildDirOnce sync.Once
)

// EnsureBuildDir creates a build directory.
func EnsureBuildDir() {
mg.Deps(dotenv.Load, output.Setup)
d := path.Join(BuildDir(), "bin")
ensure.NoError(os.MkdirAll(d, os.ModePerm))
buildDirOnce.Do(func() {
mg.Deps(dotenv.Load, output.Setup)
d := path.Join(BuildDir(), "bin")
ensure.NoError(os.MkdirAll(d, os.ModePerm))
ensure.NoError(os.MkdirAll(ReportsDir(), os.ModePerm))
if strings.Contains(ReportsDir(), randomDir) {
output.Println("📁 Reports directory: ", ReportsDir())
}
})
}

// BuildDir returns project build dir.
func BuildDir() string {
buildDir := os.Getenv("MAGE_BUILD_DIR")
if buildDir != "" {
return buildDir
}
buildDir = os.Getenv("BUILD_DIR")
if buildDir != "" {
return buildDir
}
return relativeTo(ProjectDir(), config.Actual().BuildDirPath...)
}

// ReportsDir returns project reports directory.
func ReportsDir() string {
artifacts := os.Getenv("ARTIFACTS")
if artifacts != "" {
return artifacts
return path.Join(artifacts, randomDir)
}
return relativeToProjectRoot(config.Actual().BuildDirPath)
return relativeTo(BuildDir(), "reports")
}

// ProjectDir returns project repo directory.
Expand All @@ -37,9 +66,9 @@ func ProjectDir() string {
return repoDir
}

func relativeToProjectRoot(paths []string) string {
func relativeTo(to string, paths ...string) string {
fullpath := make([]string, len(paths)+1)
fullpath[0] = ProjectDir()
fullpath[0] = to
for ix, elem := range paths {
fullpath[ix+1] = elem
}
Expand Down
6 changes: 3 additions & 3 deletions testing.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,14 +18,14 @@ func Test() {
t := tasks.Start("✅", "Testing", true)
args := []string{
"--format", "testname",
"--jsonfile", fmt.Sprintf("%s/tests-output.json", files.BuildDir()),
"--junitfile", fmt.Sprintf("%s/tests-results.junit.xml", files.BuildDir()),
"--jsonfile", fmt.Sprintf("%s/tests-output.json", files.ReportsDir()),
"--junitfile", fmt.Sprintf("%s/tests-results.junit.xml", files.ReportsDir()),
}
if color.NoColor {
args = append(args, "--no-color")
}
args = append(args, "--",
"-covermode=atomic", fmt.Sprintf("-coverprofile=%s/coverage.out", files.BuildDir()),
"-covermode=atomic", fmt.Sprintf("-coverprofile=%s/tests-coverage.out", files.ReportsDir()),
"-race",
"-count=1",
"-short",
Expand Down

0 comments on commit 2a87471

Please sign in to comment.