Unverified Commit 3d5a87e1 authored by Cristian Maglie's avatar Cristian Maglie Committed by GitHub

`board listall` (in json/machine readable output) return boards sorted with...

`board listall` (in json/machine readable output) return boards sorted with the same order as in the original `boards.txt` (#1903)

* Simplified internal boards menu maps construction

* Redesign boards build loop to iterate following boards.txt boards order

* Return board list with the same ordering as in original boards.txt

* Added integration test
parent 2ad24a76
...@@ -63,6 +63,7 @@ type PlatformRelease struct { ...@@ -63,6 +63,7 @@ type PlatformRelease struct {
Platform *Platform `json:"-"` Platform *Platform `json:"-"`
Properties *properties.Map `json:"-"` Properties *properties.Map `json:"-"`
Boards map[string]*Board `json:"-"` Boards map[string]*Board `json:"-"`
orderedBoards []*Board `json:"-"` // The Boards of this platform, in the order they are defined in the boards.txt file.
Programmers map[string]*Programmer `json:"-"` Programmers map[string]*Programmer `json:"-"`
Menus *properties.Map `json:"-"` Menus *properties.Map `json:"-"`
InstallDir *paths.Path `json:"-"` InstallDir *paths.Path `json:"-"`
...@@ -292,9 +293,16 @@ func (release *PlatformRelease) GetOrCreateBoard(boardID string) *Board { ...@@ -292,9 +293,16 @@ func (release *PlatformRelease) GetOrCreateBoard(boardID string) *Board {
PlatformRelease: release, PlatformRelease: release,
} }
release.Boards[boardID] = board release.Boards[boardID] = board
release.orderedBoards = append(release.orderedBoards, board)
return board return board
} }
// GetBoards returns the boards in this platforms in the order they
// are defined in the platform.txt file.
func (release *PlatformRelease) GetBoards() []*Board {
return release.orderedBoards
}
// RequiresToolRelease returns true if the PlatformRelease requires the // RequiresToolRelease returns true if the PlatformRelease requires the
// toolReleased passed as parameter // toolReleased passed as parameter
func (release *PlatformRelease) RequiresToolRelease(toolRelease *ToolRelease) bool { func (release *PlatformRelease) RequiresToolRelease(toolRelease *ToolRelease) bool {
......
...@@ -470,18 +470,15 @@ func (pm *Builder) loadBoards(platform *cores.PlatformRelease) error { ...@@ -470,18 +470,15 @@ func (pm *Builder) loadBoards(platform *cores.PlatformRelease) error {
return err return err
} }
propertiesByBoard := boardsProperties.FirstLevelOf() platform.Menus = boardsProperties.SubTree("menu")
if menus, ok := propertiesByBoard["menu"]; ok { // Build to boards structure following the boards.txt board ordering
platform.Menus = menus for _, boardID := range boardsProperties.FirstLevelKeys() {
} else { if boardID == "menu" {
platform.Menus = properties.NewMap() // This is not a board id so we remove it to correctly set all other boards properties
continue
} }
// This is not a board id so we remove it to correctly boardProperties := boardsProperties.SubTree(boardID)
// set all other boards properties
delete(propertiesByBoard, "menu")
for boardID, boardProperties := range propertiesByBoard {
var board *cores.Board var board *cores.Board
if !platform.PluggableDiscoveryAware { if !platform.PluggableDiscoveryAware {
convertVidPidIdentificationPropertiesToPluggableDiscovery(boardProperties) convertVidPidIdentificationPropertiesToPluggableDiscovery(boardProperties)
......
...@@ -218,6 +218,56 @@ func TestBoardOptionsFunctions(t *testing.T) { ...@@ -218,6 +218,56 @@ func TestBoardOptionsFunctions(t *testing.T) {
} }
} }
func TestBoardOrdering(t *testing.T) {
pmb := packagemanager.NewBuilder(dataDir1, dataDir1.Join("packages"), nil, nil, "")
_ = pmb.LoadHardwareFromDirectories(paths.NewPathList(dataDir1.Join("packages").String()))
pm := pmb.Build()
pme, release := pm.NewExplorer()
defer release()
pl := pme.FindPlatform(&packagemanager.PlatformReference{
Package: "arduino",
PlatformArchitecture: "avr",
})
require.NotNil(t, pl)
plReleases := pl.GetAllInstalled()
require.NotEmpty(t, plReleases)
avr := plReleases[0]
res := []string{}
for _, board := range avr.GetBoards() {
res = append(res, board.Name())
}
expected := []string{
"Arduino Yún",
"Arduino Uno",
"Arduino Duemilanove or Diecimila",
"Arduino Nano",
"Arduino Mega or Mega 2560",
"Arduino Mega ADK",
"Arduino Leonardo",
"Arduino Leonardo ETH",
"Arduino Micro",
"Arduino Esplora",
"Arduino Mini",
"Arduino Ethernet",
"Arduino Fio",
"Arduino BT",
"LilyPad Arduino USB",
"LilyPad Arduino",
"Arduino Pro or Pro Mini",
"Arduino NG or older",
"Arduino Robot Control",
"Arduino Robot Motor",
"Arduino Gemma",
"Adafruit Circuit Playground",
"Arduino Yún Mini",
"Arduino Industrial 101",
"Linino One",
"Arduino Uno WiFi",
}
require.Equal(t, expected, res)
}
func TestFindToolsRequiredForBoard(t *testing.T) { func TestFindToolsRequiredForBoard(t *testing.T) {
os.Setenv("ARDUINO_DATA_DIR", dataDir1.String()) os.Setenv("ARDUINO_DATA_DIR", dataDir1.String())
configuration.Settings = configuration.Init("") configuration.Settings = configuration.Init("")
......
...@@ -70,7 +70,7 @@ func ListAll(ctx context.Context, req *rpc.BoardListAllRequest) (*rpc.BoardListA ...@@ -70,7 +70,7 @@ func ListAll(ctx context.Context, req *rpc.BoardListAllRequest) (*rpc.BoardListA
targetPackage.Maintainer, targetPackage.Maintainer,
} }
for _, board := range installedPlatformRelease.Boards { for _, board := range installedPlatformRelease.GetBoards() {
if !req.GetIncludeHiddenBoards() && board.IsHidden() { if !req.GetIncludeHiddenBoards() && board.IsHidden() {
continue continue
} }
......
// This file is part of arduino-cli.
//
// Copyright 2022 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 board_test
import (
"testing"
"github.com/arduino/arduino-cli/internal/integrationtest"
"github.com/stretchr/testify/require"
"go.bug.st/testifyjson/requirejson"
)
func TestCorrectBoardListOrdering(t *testing.T) {
env, cli := integrationtest.CreateArduinoCLIWithEnvironment(t)
defer env.CleanUp()
_, _, err := cli.Run("core", "install", "arduino:avr")
require.NoError(t, err)
jsonOut, _, err := cli.Run("board", "listall", "--format", "json")
require.NoError(t, err)
requirejson.Query(t, jsonOut, "[.boards[] | .fqbn]", `[
"arduino:avr:yun",
"arduino:avr:uno",
"arduino:avr:unomini",
"arduino:avr:diecimila",
"arduino:avr:nano",
"arduino:avr:mega",
"arduino:avr:megaADK",
"arduino:avr:leonardo",
"arduino:avr:leonardoeth",
"arduino:avr:micro",
"arduino:avr:esplora",
"arduino:avr:mini",
"arduino:avr:ethernet",
"arduino:avr:fio",
"arduino:avr:bt",
"arduino:avr:LilyPadUSB",
"arduino:avr:lilypad",
"arduino:avr:pro",
"arduino:avr:atmegang",
"arduino:avr:robotControl",
"arduino:avr:robotMotor",
"arduino:avr:gemma",
"arduino:avr:circuitplay32u4cat",
"arduino:avr:yunmini",
"arduino:avr:chiwawa",
"arduino:avr:one",
"arduino:avr:unowifi"
]`)
}
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