Skip to content

Commit

Permalink
Merge pull request #1250 from dimaqq/upstream-type-fixes
Browse files Browse the repository at this point in the history
#1250

- update type hints in juju/application.py, pyright is now happy
- correct type hints for facade.Type
- work around pytest-dev/pytest-asyncio#1039
  • Loading branch information
jujubot authored Jan 9, 2025
2 parents a58645e + e7bcdc9 commit 1907f7a
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 22 deletions.
39 changes: 21 additions & 18 deletions juju/application.py
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
# Copyright 2023 Canonical Ltd.
# Licensed under the Apache V2, see LICENCE file for details.
from __future__ import annotations

import asyncio
import hashlib
import json
import logging
from pathlib import Path
from typing import Dict, List, Optional, Union

from typing_extensions import deprecated

Expand Down Expand Up @@ -61,7 +61,7 @@ def min_units(self) -> int:
return self.safe_data["min-units"]

@property
def constraints(self) -> Dict[str, Union[str, int, bool]]:
def constraints(self) -> dict[str, str | int | bool]:
return self.safe_data["constraints"]

@property
Expand Down Expand Up @@ -112,7 +112,7 @@ def subordinate_units(self):
return [u for u in self.units if u.is_subordinate]

@property
def relations(self) -> List[Relation]:
def relations(self) -> list[Relation]:
return [rel for rel in self.model.relations if rel.matches(self.name)]

def related_applications(self, endpoint_name=None):
Expand Down Expand Up @@ -579,7 +579,7 @@ def attach_resource(self, resource_name, file_name, file_obj):
data = file_obj.read()

headers["Content-Type"] = "application/octet-stream"
headers["Content-Length"] = len(data)
headers["Content-Length"] = str(len(data))
data_bytes = data if isinstance(data, bytes) else bytes(data, "utf-8")
headers["Content-Sha384"] = hashlib.sha384(data_bytes).hexdigest()

Expand All @@ -589,7 +589,7 @@ def attach_resource(self, resource_name, file_name, file_obj):

headers["Content-Disposition"] = f'form-data; filename="{file_name}"'
headers["Accept-Encoding"] = "gzip"
headers["Bakery-Protocol-Version"] = 3
headers["Bakery-Protocol-Version"] = "3"
headers["Connection"] = "close"

conn.request("PUT", url, data, headers)
Expand Down Expand Up @@ -638,14 +638,15 @@ async def run(self, command, timeout=None):
)

@property
def charm_name(self):
def charm_name(self) -> str:
"""Get the charm name of this application
:return str: The name of the charm
"""
return URL.parse(self.charm_url).name
return URL.parse(self.safe_data["charm-url"]).name

@property
@deprecated("Application.charm_url is deprecated and will be removed in v4")
def charm_url(self):
"""Get the charm url for this application
Expand Down Expand Up @@ -733,14 +734,14 @@ async def set_constraints(self, constraints):

async def refresh(
self,
channel: Optional[str] = None,
channel: str | None = None,
force: bool = False,
force_series: bool = False,
force_units: bool = False,
path: Optional[Union[Path, str]] = None,
resources: Optional[Dict[str, str]] = None,
revision: Optional[int] = None,
switch: Optional[str] = None,
path: Path | str | None = None,
resources: dict[str, str] | None = None,
revision: int | None = None,
switch: str | None = None,
):
"""Refresh the charm for this application.
Expand Down Expand Up @@ -841,15 +842,17 @@ async def refresh(
# need to process the given resources, as they can be
# paths or revisions
_arg_res_filenames = {}
_arg_res_revisions = {}
_arg_res_revisions: dict[str, str] = {}
for res, filename_or_rev in arg_resources.items():
if isinstance(filename_or_rev, int):
_arg_res_revisions[res] = filename_or_rev
else:
_arg_res_filenames[res] = filename_or_rev

# Get the existing resources from the ResourcesFacade
request_data = [client.Entity(self.tag)]
request_data: list[client.Entity | client.CharmResource] = [
client.Entity(self.tag)
]
resources_facade = client.ResourcesFacade.from_connection(self.connection)
response = await resources_facade.ListResources(entities=request_data)
existing_resources = {
Expand Down Expand Up @@ -930,8 +933,8 @@ async def local_refresh(
force: bool,
force_series: bool,
force_units: bool,
path: Union[Path, str],
resources: Optional[Dict[str, str]],
path: Path | str,
resources: dict[str, str] | None,
):
"""Refresh the charm for this application with a local charm.
Expand Down Expand Up @@ -1012,8 +1015,8 @@ async def get_metrics(self):

def _refresh_origin(
current_origin: client.CharmOrigin,
channel: Optional[str] = None,
revision: Optional[int] = None,
channel: str | None = None,
revision: int | None = None,
) -> client.CharmOrigin:
chan = None if channel is None else Channel.parse(channel).normalize()

Expand Down
7 changes: 5 additions & 2 deletions juju/client/facade.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@

import packaging.version
import typing_inspect
from typing_extensions import TypeAlias
from typing_extensions import Self, TypeAlias

from . import codegen

Expand Down Expand Up @@ -661,6 +661,9 @@ def default(self, obj: _RichJson) -> _Json:


class Type:
_toSchema: dict[str, str]
_toPy: dict[str, str]

def connect(self, connection):
self.connection = connection

Expand All @@ -678,7 +681,7 @@ async def rpc(self, msg: dict[str, _RichJson]) -> _Json:
return result

@classmethod
def from_json(cls, data: Type | str | dict[str, Any] | list[Any]) -> Type | None:
def from_json(cls, data: Type | str | dict[str, Any] | list[Any]) -> Self | None:
def _parse_nested_list_entry(expr, result_dict):
if isinstance(expr, str):
if ">" in expr or ">=" in expr:
Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ dependencies = [
dev = [
"typing-inspect",
"pytest",
"pytest-asyncio",
"pytest-asyncio <= 0.25.0", # https://github.com/pytest-dev/pytest-asyncio/issues/1039
"Twine",
"freezegun",
]
Expand Down
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@
"dev": [
"typing-inspect",
"pytest",
"pytest-asyncio",
"pytest-asyncio <= 0.25.0", # https://github.com/pytest-dev/pytest-asyncio/issues/1039
"Twine",
"freezegun",
]
Expand Down

0 comments on commit 1907f7a

Please sign in to comment.