Commit 5edfa984 authored by Cristian Maglie's avatar Cristian Maglie

Fixed missing `ARDUINO_USER_AGENT` env var setting. (#2501)

* Added integration test

* Fixed missing ARDUINO_USER_AGENT env var
parent ebab482d
......@@ -90,6 +90,8 @@ type Builder struct {
buildOptions *buildOptions
libsDetector *detector.SketchLibrariesDetector
toolEnv []string
}
// buildArtifacts contains the result of various build
......@@ -126,6 +128,7 @@ func NewBuilder(
libraryDirs paths.PathList,
stdout, stderr io.Writer, verbose bool, warningsLevel string,
progresCB rpc.TaskProgressCB,
toolEnv []string,
) (*Builder, error) {
buildProperties := properties.NewMap()
if boardBuildProperties != nil {
......@@ -209,6 +212,7 @@ func NewBuilder(
buildArtifacts: &buildArtifacts{},
targetPlatform: targetPlatform,
actualPlatform: actualPlatform,
toolEnv: toolEnv,
libsDetector: detector.NewSketchLibrariesDetector(
libsManager, libsResolver,
useCachedLibrariesResolution,
......@@ -493,7 +497,7 @@ func (b *Builder) prepareCommandForRecipe(buildProperties *properties.Map, recip
}
}
command, err := executils.NewProcess(nil, parts...)
command, err := executils.NewProcess(b.toolEnv, parts...)
if err != nil {
return nil, err
}
......
......@@ -199,6 +199,7 @@ func Compile(ctx context.Context, req *rpc.CompileRequest, outStream, errStream
paths.NewPathList(req.Library...),
outStream, errStream, req.GetVerbose(), req.GetWarnings(),
progressCB,
pme.GetEnvVarsForSpawnedProcess(),
)
if err != nil {
if strings.Contains(err.Error(), "invalid build properties") {
......
// This file is part of arduino-cli.
//
// Copyright 2024 ARDUINO SA (http://www.arduino.cc/)
//
// This software is released under the GNU General Public License version 3,
// which covers the main part of arduino-cli.
// The terms of this license can be found at:
// https://www.gnu.org/licenses/gpl-3.0.en.html
//
// You can be released from the requirements of the above licenses by purchasing
// a commercial license. Buying such a license is mandatory if you want to
// modify or otherwise use the software for commercial activities involving the
// Arduino software without disclosing the source code of your own applications.
// To purchase a commercial license, send an email to license@arduino.cc.
package compile_test
import (
"testing"
"github.com/arduino/arduino-cli/internal/integrationtest"
"github.com/arduino/go-paths-helper"
"github.com/stretchr/testify/require"
)
func TestCompileEnvVarOnNewProcess(t *testing.T) {
// See: https://github.com/arduino/arduino-cli/issues/2499
env, cli := integrationtest.CreateArduinoCLIWithEnvironment(t)
defer env.CleanUp()
// Run update-index with our test index
_, _, err := cli.Run("core", "install", "arduino:avr@1.8.6")
require.NoError(t, err)
// Prepare sketchbook and sketch
sketch, err := paths.New("testdata", "bare_minimum").Abs()
require.NoError(t, err)
// Build "printenv" helper insider testdata/printenv
printenvDir, err := paths.New("testdata", "printenv").Abs()
require.NoError(t, err)
builder, err := paths.NewProcess(nil, "go", "build")
require.NoError(t, err)
builder.SetDir(printenvDir.String())
require.NoError(t, builder.Run())
printenv := printenvDir.Join("printenv")
// Patch avr core to run printenv instead of size
plTxt, err := cli.DataDir().Join("packages", "arduino", "hardware", "avr", "1.8.6", "platform.txt").Append()
require.NoError(t, err)
_, err = plTxt.WriteString("recipe.size.pattern=" + printenv.String() + "\n")
require.NoError(t, err)
require.NoError(t, plTxt.Close())
// Run compile and get ENV
_, stderr, err := cli.Run("compile", "-v", "-b", "arduino:avr:uno", sketch.String())
require.NoError(t, err)
require.Contains(t, string(stderr), "ENV> ARDUINO_USER_AGENT=")
}
package main
import (
"fmt"
"os"
)
func main() {
for _, env := range os.Environ() {
fmt.Fprintln(os.Stderr, "ENV>", env)
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment