Merge branch 'develop' into feature/v7

# Conflicts:
#	docs
This commit is contained in:
Ivan Kravets
2024-03-16 18:00:14 +02:00
14 changed files with 139 additions and 67 deletions

View File

@@ -7,6 +7,7 @@ Release Notes
.. |INTERPOLATION| replace:: `Interpolation of Values <https://docs.platformio.org/en/latest/projectconf/interpolation.html>`__ .. |INTERPOLATION| replace:: `Interpolation of Values <https://docs.platformio.org/en/latest/projectconf/interpolation.html>`__
.. |UNITTESTING| replace:: `Unit Testing <https://docs.platformio.org/en/latest/advanced/unit-testing/index.html>`__ .. |UNITTESTING| replace:: `Unit Testing <https://docs.platformio.org/en/latest/advanced/unit-testing/index.html>`__
.. |DEBUGGING| replace:: `Debugging <https://docs.platformio.org/en/latest/plus/debugging.html>`__ .. |DEBUGGING| replace:: `Debugging <https://docs.platformio.org/en/latest/plus/debugging.html>`__
.. |STATICCODEANALYSIS| replace:: `Static Code Analysis <https://docs.platformio.org/en/latest/advanced/static-code-analysis/index.html>`__
.. _release_notes_6: .. _release_notes_6:
@@ -23,6 +24,8 @@ test-driven methodologies, and modern toolchains for unrivaled success.
* Introduced the ``--json-output`` option to the `pio test <https://docs.platformio.org/en/latest/core/userguide/cmd_test.html>`__ command, enabling users to generate test results in the JSON format * Introduced the ``--json-output`` option to the `pio test <https://docs.platformio.org/en/latest/core/userguide/cmd_test.html>`__ command, enabling users to generate test results in the JSON format
* Broadened version support for the ``pyelftools`` dependency, enabling compatibility with lower versions and facilitating integration with a wider range of third-party tools (`issue #4834 <https://github.com/platformio/platformio-core/issues/4834>`_) * Broadened version support for the ``pyelftools`` dependency, enabling compatibility with lower versions and facilitating integration with a wider range of third-party tools (`issue #4834 <https://github.com/platformio/platformio-core/issues/4834>`_)
* Addressed an issue where passing a relative path (``--project-dir``) to the `pio project init <https://docs.platformio.org/en/latest/core/userguide/project/cmd_init.html>`__ command resulted in an error (`issue #4847 <https://github.com/platformio/platformio-core/issues/4847>`_) * Addressed an issue where passing a relative path (``--project-dir``) to the `pio project init <https://docs.platformio.org/en/latest/core/userguide/project/cmd_init.html>`__ command resulted in an error (`issue #4847 <https://github.com/platformio/platformio-core/issues/4847>`_)
* Enhanced |STATICCODEANALYSIS| to accommodate scenarios where custom ``src_dir`` or ``include_dir`` are located outside the project folder (`pull #4874 <https://github.com/platformio/platformio-core/pull/4874>`_)
* Corrected the validation of ``symlink://`` `package specifications <https://docs.platformio.org/en/latest/core/userguide/pkg/cmd_install.html#local-folder>`__ , resolving an issue that caused the package manager to repeatedly reinstall dependencies (`pull #4870 <https://github.com/platformio/platformio-core/pull/4870>`_)
* Resolved an issue related to the relative package path in the `pio pkg publish <https://docs.platformio.org/en/latest/core/userguide/pkg/cmd_publish.html>`__ command * Resolved an issue related to the relative package path in the `pio pkg publish <https://docs.platformio.org/en/latest/core/userguide/pkg/cmd_publish.html>`__ command
* Resolved an issue where the |LDF| selected an incorrect library version (`issue #4860 <https://github.com/platformio/platformio-core/issues/4860>`_) * Resolved an issue where the |LDF| selected an incorrect library version (`issue #4860 <https://github.com/platformio/platformio-core/issues/4860>`_)
* Resolved an issue with the ``hexlify`` filter in the `device monitor <https://docs.platformio.org/en/latest/core/userguide/device/cmd_monitor.html>`__ command, ensuring proper representation of characters with Unicode code points higher than 127 (`issue #4732 <https://github.com/platformio/platformio-core/issues/4732>`_) * Resolved an issue with the ``hexlify`` filter in the `device monitor <https://docs.platformio.org/en/latest/core/userguide/device/cmd_monitor.html>`__ command, ensuring proper representation of characters with Unicode code points higher than 127 (`issue #4732 <https://github.com/platformio/platformio-core/issues/4732>`_)

2
docs

Submodule docs updated: 1c8479f3d0...ad1f7f90c5

View File

@@ -12,7 +12,7 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
VERSION = (6, 1, "14b1") VERSION = (6, 1, "14rc1")
__version__ = ".".join([str(s) for s in VERSION]) __version__ = ".".join([str(s) for s in VERSION])
__title__ = "platformio" __title__ = "platformio"

View File

@@ -103,10 +103,21 @@ def cli(
"%s: %s" % (k, ", ".join(v) if isinstance(v, list) else v) "%s: %s" % (k, ", ".join(v) if isinstance(v, list) else v)
) )
default_src_filters = [ default_src_filters = []
"+<%s>" % os.path.basename(config.get("platformio", "src_dir")), for d in (
"+<%s>" % os.path.basename(config.get("platformio", "include_dir")), config.get("platformio", "src_dir"),
] config.get("platformio", "include_dir"),
):
try:
default_src_filters.append("+<%s>" % os.path.relpath(d))
except ValueError as exc:
# On Windows if sources are located on a different logical drive
if not json_output and not silent:
click.echo(
"Error: Project cannot be analyzed! The project folder `%s`"
" is located on a different logical drive\n" % d
)
raise exception.ReturnErrorCode(1) from exc
env_src_filters = ( env_src_filters = (
src_filters src_filters

View File

@@ -280,11 +280,15 @@ class BasePackageManager( # pylint: disable=too-many-public-methods,too-many-in
# external "URL" mismatch # external "URL" mismatch
if spec.external: if spec.external:
# local folder mismatch # local/symlinked folder mismatch
if os.path.abspath(spec.uri) == os.path.abspath(pkg.path) or ( check_conds = [
os.path.abspath(spec.uri) == os.path.abspath(pkg.path),
spec.uri.startswith("file://") spec.uri.startswith("file://")
and os.path.abspath(pkg.path) == os.path.abspath(spec.uri[7:]) and os.path.abspath(pkg.path) == os.path.abspath(spec.uri[7:]),
): spec.uri.startswith("symlink://")
and os.path.abspath(pkg.path) == os.path.abspath(spec.uri[10:]),
]
if any(check_conds):
return True return True
if spec.uri != pkg.metadata.spec.uri: if spec.uri != pkg.metadata.spec.uri:
return False return False

View File

@@ -13,6 +13,7 @@
# limitations under the License. # limitations under the License.
import os import os
import sys
from tarfile import open as tarfile_open from tarfile import open as tarfile_open
from time import mktime from time import mktime
from zipfile import ZipFile from zipfile import ZipFile
@@ -82,19 +83,23 @@ class TARArchiver(BaseArchiver):
).startswith(base) ).startswith(base)
def extract_item(self, item, dest_dir): def extract_item(self, item, dest_dir):
if sys.version_info >= (3, 12):
self._afo.extract(item, dest_dir, filter="data")
return self.after_extract(item, dest_dir)
# apply custom security logic
dest_dir = self.resolve_path(dest_dir) dest_dir = self.resolve_path(dest_dir)
bad_conds = [ bad_conds = [
self.is_bad_path(item.name, dest_dir), self.is_bad_path(item.name, dest_dir),
self.is_link(item) and self.is_bad_link(item, dest_dir), self.is_link(item) and self.is_bad_link(item, dest_dir),
] ]
if not any(bad_conds): if any(bad_conds):
super().extract_item(item, dest_dir) return click.secho(
else:
click.secho(
"Blocked insecure item `%s` from TAR archive" % item.name, "Blocked insecure item `%s` from TAR archive" % item.name,
fg="red", fg="red",
err=True, err=True,
) )
return super().extract_item(item, dest_dir)
class ZIPArchiver(BaseArchiver): class ZIPArchiver(BaseArchiver):

View File

@@ -36,7 +36,7 @@ def get_pip_dependencies():
# PIO Home requirements # PIO Home requirements
"ajsonrpc == 1.2.*", "ajsonrpc == 1.2.*",
"starlette >=0.19, <0.38", "starlette >=0.19, <0.38",
"uvicorn %s" % ("== 0.16.0" if PY36 else ">=0.16, <0.28"), "uvicorn %s" % ("== 0.16.0" if PY36 else ">=0.16, <0.29"),
"wsproto == 1.*", "wsproto == 1.*",
] ]

View File

@@ -24,7 +24,7 @@ PROJECT_OUTDATED_CONFIG_TPL = """
platform = platformio/atmelavr@^2 platform = platformio/atmelavr@^2
framework = arduino framework = arduino
board = attiny88 board = attiny88
lib_deps = milesburton/DallasTemperature@~3.8.0 lib_deps = milesburton/DallasTemperature@~3.9.0
""" """
PROJECT_UPDATED_CONFIG_TPL = """ PROJECT_UPDATED_CONFIG_TPL = """
@@ -32,7 +32,7 @@ PROJECT_UPDATED_CONFIG_TPL = """
platform = platformio/atmelavr@<4 platform = platformio/atmelavr@<4
framework = arduino framework = arduino
board = attiny88 board = attiny88
lib_deps = milesburton/DallasTemperature@^3.8.0 lib_deps = milesburton/DallasTemperature@^3.9.0
""" """
@@ -56,7 +56,7 @@ def test_project(clirunner, validate_cliresult, isolated_pio_core, tmp_path):
re.MULTILINE, re.MULTILINE,
) )
assert re.search( assert re.search(
r"^DallasTemperature\s+3\.8\.1\s+3\.\d+\.\d+\s+3\.\d+\.\d+\s+Library\s+devkit", r"^DallasTemperature\s+3\.\d\.1\s+3\.\d+\.\d+\s+3\.\d+\.\d+\s+Library\s+devkit",
result.output, result.output,
re.MULTILINE, re.MULTILINE,
) )

View File

@@ -26,12 +26,14 @@ from platformio.package.manager.tool import ToolPackageManager
from platformio.package.meta import PackageSpec from platformio.package.meta import PackageSpec
from platformio.project.config import ProjectConfig from platformio.project.config import ProjectConfig
DALLASTEMPERATURE_LATEST_VERSION = "3.11.0"
PROJECT_OUTDATED_CONFIG_TPL = """ PROJECT_OUTDATED_CONFIG_TPL = """
[env:devkit] [env:devkit]
platform = platformio/atmelavr@^2 platform = platformio/atmelavr@^2
framework = arduino framework = arduino
board = attiny88 board = attiny88
lib_deps = milesburton/DallasTemperature@~3.8.0 lib_deps = milesburton/DallasTemperature@^3.8.0
""" """
PROJECT_UPDATED_CONFIG_TPL = """ PROJECT_UPDATED_CONFIG_TPL = """
@@ -162,7 +164,7 @@ def test_project(
os.path.join(config.get("platformio", "libdeps_dir"), "devkit") os.path.join(config.get("platformio", "libdeps_dir"), "devkit")
) )
assert pkgs_to_specs(lm.get_installed()) == [ assert pkgs_to_specs(lm.get_installed()) == [
PackageSpec("DallasTemperature@3.8.1"), PackageSpec(f"DallasTemperature@{DALLASTEMPERATURE_LATEST_VERSION}"),
PackageSpec( PackageSpec(
"OneWire@%s" % get_pkg_latest_version("paulstoffregen/OneWire") "OneWire@%s" % get_pkg_latest_version("paulstoffregen/OneWire")
), ),
@@ -176,7 +178,7 @@ def test_project(
PackageSpec("toolchain-atmelavr@1.50400.190710"), PackageSpec("toolchain-atmelavr@1.50400.190710"),
] ]
assert config.get("env:devkit", "lib_deps") == [ assert config.get("env:devkit", "lib_deps") == [
"milesburton/DallasTemperature@~3.8.0" "milesburton/DallasTemperature@^3.8.0"
] ]
# update packages # update packages
@@ -227,7 +229,7 @@ def test_custom_project_libraries(
project_dir = tmp_path / "project" project_dir = tmp_path / "project"
project_dir.mkdir() project_dir.mkdir()
(project_dir / "platformio.ini").write_text(PROJECT_OUTDATED_CONFIG_TPL) (project_dir / "platformio.ini").write_text(PROJECT_OUTDATED_CONFIG_TPL)
spec = "milesburton/DallasTemperature@~3.8.0" spec = "milesburton/DallasTemperature@^3.8.0"
result = clirunner.invoke( result = clirunner.invoke(
package_install_cmd, package_install_cmd,
["-d", str(project_dir), "-e", "devkit", "-l", spec], ["-d", str(project_dir), "-e", "devkit", "-l", spec],
@@ -240,7 +242,7 @@ def test_custom_project_libraries(
os.path.join(config.get("platformio", "libdeps_dir"), "devkit") os.path.join(config.get("platformio", "libdeps_dir"), "devkit")
) )
assert pkgs_to_specs(lm.get_installed()) == [ assert pkgs_to_specs(lm.get_installed()) == [
PackageSpec("DallasTemperature@3.8.1"), PackageSpec(f"DallasTemperature@{DALLASTEMPERATURE_LATEST_VERSION}"),
PackageSpec( PackageSpec(
"OneWire@%s" % get_pkg_latest_version("paulstoffregen/OneWire") "OneWire@%s" % get_pkg_latest_version("paulstoffregen/OneWire")
), ),

View File

@@ -803,3 +803,49 @@ check_src_filters =
assert errors + warnings + style == EXPECTED_DEFECTS assert errors + warnings + style == EXPECTED_DEFECTS
assert "test.cpp" in result.output assert "test.cpp" in result.output
assert "main.cpp" not in result.output assert "main.cpp" not in result.output
def test_check_sources_in_project_root(clirunner, validate_cliresult, tmpdir_factory):
tmpdir = tmpdir_factory.mktemp("project")
config = (
"""
[platformio]
src_dir = ./
"""
+ DEFAULT_CONFIG
)
tmpdir.join("platformio.ini").write(config)
tmpdir.join("main.cpp").write(TEST_CODE)
tmpdir.mkdir("spi").join("uart.cpp").write(TEST_CODE)
result = clirunner.invoke(cmd_check, ["--project-dir", str(tmpdir)])
validate_cliresult(result)
errors, warnings, style = count_defects(result.output)
assert result.exit_code == 0
assert errors + warnings + style == EXPECTED_DEFECTS * 2
def test_check_sources_in_external_dir(clirunner, validate_cliresult, tmpdir_factory):
tmpdir = tmpdir_factory.mktemp("project")
external_src_dir = tmpdir_factory.mktemp("external_src_dir")
config = (
f"""
[platformio]
src_dir = {external_src_dir}
"""
+ DEFAULT_CONFIG
)
tmpdir.join("platformio.ini").write(config)
external_src_dir.join("main.cpp").write(TEST_CODE)
result = clirunner.invoke(cmd_check, ["--project-dir", str(tmpdir)])
validate_cliresult(result)
errors, warnings, style = count_defects(result.output)
assert result.exit_code == 0
assert errors + warnings + style == EXPECTED_DEFECTS

View File

@@ -42,7 +42,7 @@ board = devkit
framework = foo framework = foo
lib_deps = lib_deps =
CustomLib CustomLib
ArduinoJson @ 5.10.1 ArduinoJson @ 6.18.5
""" """
) )
result = clirunner.invoke( result = clirunner.invoke(
@@ -163,7 +163,7 @@ def test_update(clirunner, validate_cliresult, isolated_pio_core, tmpdir_factory
storage_dir = tmpdir_factory.mktemp("test-updates") storage_dir = tmpdir_factory.mktemp("test-updates")
result = clirunner.invoke( result = clirunner.invoke(
cmd_lib, cmd_lib,
["-d", str(storage_dir), "install", "ArduinoJson @ 5.10.1", "Blynk @ ~0.5.0"], ["-d", str(storage_dir), "install", "ArduinoJson @ 6.18.5", "Blynk @ ~1.2"],
) )
validate_cliresult(result) validate_cliresult(result)
result = clirunner.invoke( result = clirunner.invoke(
@@ -173,17 +173,17 @@ def test_update(clirunner, validate_cliresult, isolated_pio_core, tmpdir_factory
outdated = json.loads(result.stdout) outdated = json.loads(result.stdout)
assert len(outdated) == 2 assert len(outdated) == 2
# ArduinoJson # ArduinoJson
assert outdated[0]["version"] == "5.10.1" assert outdated[0]["version"] == "6.18.5"
assert outdated[0]["versionWanted"] is None assert outdated[0]["versionWanted"] is None
assert semantic_version.Version( assert semantic_version.Version(
outdated[0]["versionLatest"] outdated[0]["versionLatest"]
) > semantic_version.Version("6.16.0") ) > semantic_version.Version("6.18.5")
# Blynk # Blynk
assert outdated[1]["version"] == "0.5.4" assert outdated[1]["version"] == "1.2.0"
assert outdated[1]["versionWanted"] is None assert outdated[1]["versionWanted"] is None
assert semantic_version.Version( assert semantic_version.Version(
outdated[1]["versionLatest"] outdated[1]["versionLatest"]
) > semantic_version.Version("0.6.0") ) > semantic_version.Version("1.2.0")
# check with spec # check with spec
result = clirunner.invoke( result = clirunner.invoke(
@@ -194,19 +194,19 @@ def test_update(clirunner, validate_cliresult, isolated_pio_core, tmpdir_factory
"update", "update",
"--dry-run", "--dry-run",
"--json-output", "--json-output",
"ArduinoJson @ ^5", "ArduinoJson @ ^6",
], ],
) )
validate_cliresult(result) validate_cliresult(result)
outdated = json.loads(result.stdout) outdated = json.loads(result.stdout)
assert outdated[0]["version"] == "5.10.1" assert outdated[0]["version"] == "6.18.5"
assert outdated[0]["versionWanted"] == "5.13.4" assert outdated[0]["versionWanted"] == "6.21.5"
assert semantic_version.Version( assert semantic_version.Version(
outdated[0]["versionLatest"] outdated[0]["versionLatest"]
) > semantic_version.Version("6.16.0") ) > semantic_version.Version("6.16.0")
# update with spec # update with spec
result = clirunner.invoke( result = clirunner.invoke(
cmd_lib, ["-d", str(storage_dir), "update", "--silent", "ArduinoJson @ ^5.10.1"] cmd_lib, ["-d", str(storage_dir), "update", "--silent", "ArduinoJson @ ^6.18.5"]
) )
validate_cliresult(result) validate_cliresult(result)
result = clirunner.invoke( result = clirunner.invoke(
@@ -215,12 +215,12 @@ def test_update(clirunner, validate_cliresult, isolated_pio_core, tmpdir_factory
validate_cliresult(result) validate_cliresult(result)
items = json.loads(result.stdout) items = json.loads(result.stdout)
assert len(items) == 2 assert len(items) == 2
assert items[0]["version"] == "5.13.4" assert items[0]["version"] == "6.21.5"
assert items[1]["version"] == "0.5.4" assert items[1]["version"] == "1.2.0"
# Check incompatible # Check incompatible
result = clirunner.invoke( result = clirunner.invoke(
cmd_lib, ["-d", str(storage_dir), "update", "--dry-run", "ArduinoJson @ ^5"] cmd_lib, ["-d", str(storage_dir), "update", "--dry-run", "ArduinoJson @ ^6"]
) )
with pytest.raises( with pytest.raises(
AssertionError, AssertionError,
@@ -228,7 +228,7 @@ def test_update(clirunner, validate_cliresult, isolated_pio_core, tmpdir_factory
): ):
validate_cliresult(result) validate_cliresult(result)
result = clirunner.invoke( result = clirunner.invoke(
cmd_lib, ["-d", str(storage_dir), "update", "ArduinoJson @ ^5"] cmd_lib, ["-d", str(storage_dir), "update", "ArduinoJson @ ^6"]
) )
validate_cliresult(result) validate_cliresult(result)
assert "ArduinoJson@5.13.4 is already up-to-date" in result.stdout assert "ArduinoJson@6.21.5 is already up-to-date" in result.stdout

View File

@@ -23,6 +23,7 @@ from platformio.package.exception import UnknownPackageError
from platformio.util import strip_ansi_codes from platformio.util import strip_ansi_codes
PlatformioCLI.leftover_args = ["--json-output"] # hook for click PlatformioCLI.leftover_args = ["--json-output"] # hook for click
ARDUINO_JSON_VERSION = "6.21.5"
def test_search(clirunner, validate_cliresult): def test_search(clirunner, validate_cliresult):
@@ -44,10 +45,10 @@ def test_global_install_registry(clirunner, validate_cliresult, isolated_pio_cor
"-g", "-g",
"install", "install",
"64", "64",
"ArduinoJson@~5.10.0", "ArduinoJson@~6",
"547@2.2.4", "547@2.7.3",
"AsyncMqttClient@<=0.8.2", "AsyncMqttClient@<=0.8.2",
"Adafruit PN532@1.2.0", "Adafruit PN532@1.3.2",
], ],
) )
validate_cliresult(result) validate_cliresult(result)
@@ -60,7 +61,7 @@ def test_global_install_registry(clirunner, validate_cliresult, isolated_pio_cor
items1 = [d.basename for d in isolated_pio_core.join("lib").listdir()] items1 = [d.basename for d in isolated_pio_core.join("lib").listdir()]
items2 = [ items2 = [
"ArduinoJson", "ArduinoJson",
"ArduinoJson@5.10.1", f"ArduinoJson@{ARDUINO_JSON_VERSION}",
"NeoPixelBus", "NeoPixelBus",
"AsyncMqttClient", "AsyncMqttClient",
"ESPAsyncTCP", "ESPAsyncTCP",
@@ -79,7 +80,7 @@ def test_global_install_archive(clirunner, validate_cliresult, isolated_pio_core
"install", "install",
"https://github.com/bblanchon/ArduinoJson/archive/v5.8.2.zip", "https://github.com/bblanchon/ArduinoJson/archive/v5.8.2.zip",
"https://github.com/bblanchon/ArduinoJson/archive/v5.8.2.zip@5.8.2", "https://github.com/bblanchon/ArduinoJson/archive/v5.8.2.zip@5.8.2",
"SomeLib=https://dl.registry.platformio.org/download/milesburton/library/DallasTemperature/3.8.1/DallasTemperature-3.8.1.tar.gz", "SomeLib=https://dl.registry.platformio.org/download/milesburton/library/DallasTemperature/3.11.0/DallasTemperature-3.11.0.tar.gz",
"https://github.com/Pedroalbuquerque/ESP32WebServer/archive/master.zip", "https://github.com/Pedroalbuquerque/ESP32WebServer/archive/master.zip",
], ],
) )
@@ -142,7 +143,7 @@ def test_install_duplicates( # pylint: disable=unused-argument
[ [
"-g", "-g",
"install", "install",
"https://dl.registry.platformio.org/download/milesburton/library/DallasTemperature/3.8.1/DallasTemperature-3.8.1.tar.gz", "https://dl.registry.platformio.org/download/milesburton/library/DallasTemperature/3.11.0/DallasTemperature-3.11.0.tar.gz",
], ],
) )
validate_cliresult(result) validate_cliresult(result)
@@ -176,11 +177,11 @@ def test_global_lib_list(clirunner, validate_cliresult):
n in result.output n in result.output
for n in ( for n in (
"required: https://github.com/Pedroalbuquerque/ESP32WebServer/archive/master.zip", "required: https://github.com/Pedroalbuquerque/ESP32WebServer/archive/master.zip",
"ArduinoJson @ 5.10.1", f"ArduinoJson @ {ARDUINO_JSON_VERSION}",
"required: git+https://github.com/gioblu/PJON.git#3.0", "required: git+https://github.com/gioblu/PJON.git#3.0",
"PJON @ 3.0.0+sha.1fb26f", "PJON @ 3.0.0+sha.1fb26f",
) )
) ), result.output
result = clirunner.invoke(cmd_lib, ["-g", "list", "--json-output"]) result = clirunner.invoke(cmd_lib, ["-g", "list", "--json-output"])
assert all( assert all(
@@ -188,7 +189,7 @@ def test_global_lib_list(clirunner, validate_cliresult):
for n in ( for n in (
"__pkg_dir", "__pkg_dir",
'"__src_url": "git+https://github.com/gioblu/PJON.git#6.2"', '"__src_url": "git+https://github.com/gioblu/PJON.git#6.2"',
'"version": "5.10.1"', f'"version": "{ARDUINO_JSON_VERSION}"',
) )
) )
items1 = [i["name"] for i in json.loads(result.output)] items1 = [i["name"] for i in json.loads(result.output)]
@@ -218,13 +219,13 @@ def test_global_lib_list(clirunner, validate_cliresult):
] ]
versions2 = [ versions2 = [
"ArduinoJson@5.8.2", "ArduinoJson@5.8.2",
"ArduinoJson@5.10.1", f"ArduinoJson@{ARDUINO_JSON_VERSION}",
"AsyncMqttClient@0.8.2", "AsyncMqttClient@0.8.2",
"NeoPixelBus@2.2.4", "NeoPixelBus@2.7.3",
"PJON@6.2.0+sha.07fe9aa", "PJON@6.2.0+sha.07fe9aa",
"PJON@3.0.0+sha.1fb26fd", "PJON@3.0.0+sha.1fb26fd",
"PubSubClient@2.6.0+sha.bef5814", "PubSubClient@2.6.0+sha.bef5814",
"Adafruit PN532@1.2.0", "Adafruit PN532@1.3.2",
] ]
assert set(versions1) >= set(versions2) assert set(versions1) >= set(versions2)
@@ -249,7 +250,7 @@ def test_global_lib_update(clirunner, validate_cliresult):
assert "__pkg_dir" in oudated[0] assert "__pkg_dir" in oudated[0]
result = clirunner.invoke(cmd_lib, ["-g", "update", oudated[0]["__pkg_dir"]]) result = clirunner.invoke(cmd_lib, ["-g", "update", oudated[0]["__pkg_dir"]])
validate_cliresult(result) validate_cliresult(result)
assert "Removing NeoPixelBus @ 2.2.4" in strip_ansi_codes(result.output) assert "Removing NeoPixelBus @ 2.7.3" in strip_ansi_codes(result.output)
# update all libraries # update all libraries
result = clirunner.invoke( result = clirunner.invoke(

View File

@@ -63,7 +63,7 @@ def test_install_unknown_from_registry(clirunner):
def test_install_core_3_dev_platform(clirunner, validate_cliresult, isolated_pio_core): def test_install_core_3_dev_platform(clirunner, validate_cliresult, isolated_pio_core):
result = clirunner.invoke( result = clirunner.invoke(
cli_platform.platform_install, cli_platform.platform_install,
["atmelavr@1.2.0", "--skip-default-package"], ["atmelavr@2.2.0", "--skip-default-package"],
) )
assert result.exit_code == 0 assert result.exit_code == 0
@@ -71,11 +71,11 @@ def test_install_core_3_dev_platform(clirunner, validate_cliresult, isolated_pio
def test_install_known_version(clirunner, validate_cliresult, isolated_pio_core): def test_install_known_version(clirunner, validate_cliresult, isolated_pio_core):
result = clirunner.invoke( result = clirunner.invoke(
cli_platform.platform_install, cli_platform.platform_install,
["atmelavr@2.0.0", "--skip-default-package", "--with-package", "tool-avrdude"], ["atmelavr@4.2.0", "--skip-default-package", "--with-package", "tool-avrdude"],
) )
validate_cliresult(result) validate_cliresult(result)
output = strip_ansi_codes(result.output) output = strip_ansi_codes(result.output)
assert "atmelavr @ 2.0.0" in output assert "atmelavr@4.2.0" in output
assert not os.path.isdir(str(isolated_pio_core.join("packages"))) assert not os.path.isdir(str(isolated_pio_core.join("packages")))
@@ -128,14 +128,14 @@ def test_update_raw(clirunner, validate_cliresult, isolated_pio_core):
result = clirunner.invoke(cli_platform.platform_update, ["atmelavr"]) result = clirunner.invoke(cli_platform.platform_update, ["atmelavr"])
validate_cliresult(result) validate_cliresult(result)
output = strip_ansi_codes(result.output) output = strip_ansi_codes(result.output)
assert "Removing atmelavr @ 2.0.0" in output assert "Removing atmelavr @ 4.2.0" in output
assert "Platform Manager: Installing platformio/atmelavr @" in output assert "Platform Manager: Installing platformio/atmelavr @" in output
assert len(isolated_pio_core.join("packages").listdir()) == 2 assert len(isolated_pio_core.join("packages").listdir()) == 2
def test_uninstall(clirunner, validate_cliresult, isolated_pio_core): def test_uninstall(clirunner, validate_cliresult, isolated_pio_core):
result = clirunner.invoke( result = clirunner.invoke(
cli_platform.platform_uninstall, ["atmelavr@1.2.0", "atmelavr", "espressif8266"] cli_platform.platform_uninstall, ["atmelavr@2.2.0", "atmelavr", "espressif8266"]
) )
validate_cliresult(result) validate_cliresult(result)
assert not isolated_pio_core.join("platforms").listdir() assert not isolated_pio_core.join("platforms").listdir()

View File

@@ -219,7 +219,7 @@ def test_install_from_registry(isolated_pio_core, tmpdir_factory):
# test conflicted names # test conflicted names
lm = LibraryPackageManager(str(tmpdir_factory.mktemp("conflicted-storage"))) lm = LibraryPackageManager(str(tmpdir_factory.mktemp("conflicted-storage")))
lm.set_log_level(logging.ERROR) lm.set_log_level(logging.ERROR)
lm.install("z3t0/IRremote@2.6.1") lm.install("z3t0/IRremote")
lm.install("mbed-yuhki50/IRremote") lm.install("mbed-yuhki50/IRremote")
assert len(lm.get_installed()) == 2 assert len(lm.get_installed()) == 2
@@ -554,14 +554,14 @@ def test_uninstall(isolated_pio_core, tmpdir_factory):
assert not lm.get_installed() assert not lm.get_installed()
# test uninstall dependencies # test uninstall dependencies
assert lm.install("AsyncMqttClient-esphome @ 0.8.4") assert lm.install("AsyncMqttClient-esphome")
assert len(lm.get_installed()) == 3 assert len(lm.get_installed()) == 3
assert lm.uninstall("AsyncMqttClient-esphome", skip_dependencies=True) assert lm.uninstall("AsyncMqttClient-esphome", skip_dependencies=True)
assert len(lm.get_installed()) == 2 assert len(lm.get_installed()) == 2
lm = LibraryPackageManager(str(storage_dir)) lm = LibraryPackageManager(str(storage_dir))
lm.set_log_level(logging.ERROR) lm.set_log_level(logging.ERROR)
assert lm.install("AsyncMqttClient-esphome @ 0.8.4") assert lm.install("AsyncMqttClient-esphome")
assert lm.uninstall("AsyncMqttClient-esphome") assert lm.uninstall("AsyncMqttClient-esphome")
assert not lm.get_installed() assert not lm.get_installed()
@@ -604,23 +604,23 @@ def test_update_with_metadata(isolated_pio_core, tmpdir_factory):
assert str(outdated.current) == "1.8.7" assert str(outdated.current) == "1.8.7"
assert outdated.latest > semantic_version.Version("1.10.0") assert outdated.latest > semantic_version.Version("1.10.0")
pkg = lm.install("ArduinoJson @ 5.10.1") pkg = lm.install("ArduinoJson @ 6.19.4")
# test latest # test latest
outdated = lm.outdated(pkg) outdated = lm.outdated(pkg)
assert str(outdated.current) == "5.10.1" assert str(outdated.current) == "6.19.4"
assert outdated.wanted is None assert outdated.wanted is None
assert outdated.latest > outdated.current assert outdated.latest > outdated.current
assert outdated.latest > semantic_version.Version("5.99.99") assert outdated.latest > semantic_version.Version("5.99.99")
# test wanted # test wanted
outdated = lm.outdated(pkg, PackageSpec("ArduinoJson@~5")) outdated = lm.outdated(pkg, PackageSpec("ArduinoJson@~6"))
assert str(outdated.current) == "5.10.1" assert str(outdated.current) == "6.19.4"
assert str(outdated.wanted) == "5.13.4" assert str(outdated.wanted) == "6.21.5"
assert outdated.latest > semantic_version.Version("6.16.0") assert outdated.latest > semantic_version.Version("6.16.0")
# update to the wanted 5.x # update to the wanted 6.x
new_pkg = lm.update("ArduinoJson@^5", PackageSpec("ArduinoJson@^5")) new_pkg = lm.update("ArduinoJson@^6", PackageSpec("ArduinoJson@^6"))
assert str(new_pkg.metadata.version) == "5.13.4" assert str(new_pkg.metadata.version) == "6.21.5"
# check that old version is removed # check that old version is removed
assert len(lm.get_installed()) == 2 assert len(lm.get_installed()) == 2