flake8 fixes

This commit is contained in:
Cayo Puigdefabregas 2022-03-29 17:20:58 +02:00
parent 1c74e27fd2
commit 7e9a78428a
3 changed files with 8 additions and 86 deletions

View file

@ -27,8 +27,7 @@ from wtforms.fields import FormField
from ereuse_devicehub.db import db from ereuse_devicehub.db import db
from ereuse_devicehub.parser.parser import ParseSnapshotLsHw from ereuse_devicehub.parser.parser import ParseSnapshotLsHw
from ereuse_devicehub.resources.action.models import RateComputer, Snapshot, Trade from ereuse_devicehub.resources.action.models import Snapshot, Trade
from ereuse_devicehub.resources.action.rate.v1_0 import CannotRate
from ereuse_devicehub.resources.action.schemas import Snapshot as SnapshotSchema from ereuse_devicehub.resources.action.schemas import Snapshot as SnapshotSchema
from ereuse_devicehub.resources.action.schemas import Snapshot_lite from ereuse_devicehub.resources.action.schemas import Snapshot_lite
from ereuse_devicehub.resources.action.views.snapshot import move_json, save_json from ereuse_devicehub.resources.action.views.snapshot import move_json, save_json

View file

@ -1,18 +1,16 @@
import json import json
import os
import re import re
import subprocess import subprocess
from contextlib import suppress from contextlib import suppress
from datetime import datetime from datetime import datetime
from enum import Enum, unique from enum import Enum, unique
from fractions import Fraction from fractions import Fraction
from subprocess import PIPE, CalledProcessError, run from subprocess import PIPE, run
from typing import Iterator, List, Optional, Tuple, Type, TypeVar from typing import Iterator, List, Optional, Type, TypeVar
from warnings import catch_warnings, filterwarnings from warnings import catch_warnings, filterwarnings
import dateutil.parser import dateutil.parser
import pySMART import pySMART
from ereuse_utils import cmd
from ereuse_utils import getter as g from ereuse_utils import getter as g
from ereuse_utils import text from ereuse_utils import text
from ereuse_utils.nested_lookup import ( from ereuse_utils.nested_lookup import (
@ -97,7 +95,7 @@ class Processor(Component):
assert not hasattr(self, 'cores') or 1 <= self.cores <= 16 assert not hasattr(self, 'cores') or 1 <= self.cores <= 16
@staticmethod @staticmethod # noqa: C901
def processor_brand_generation(model: str): def processor_brand_generation(model: str):
"""Generates the ``brand`` and ``generation`` fields for the given model. """Generates the ``brand`` and ``generation`` fields for the given model.
@ -105,10 +103,11 @@ class Processor(Component):
- The brand as a string or None. - The brand as a string or None.
- The generation as an int or None. - The generation as an int or None.
Intel desktop processor numbers:
https://www.intel.com/content/www/us/en/processors/processor-numbers.html
Intel server processor numbers:
https://www.intel.com/content/www/us/en/processors/processor-numbers-data-center.html
""" """
# Intel desktop processor numbers: https://www.intel.com/content/www/us/en/processors/processor-numbers.html
# Intel server processor numbers: https://www.intel.com/content/www/us/en/processors/processor-numbers-data-center.html
if 'Duo' in model: if 'Duo' in model:
return 'Core2 Duo', None return 'Core2 Duo', None
if 'Quad' in model: if 'Quad' in model:
@ -447,76 +446,6 @@ class Display(Component):
) )
class Battery(Component):
class Technology(Enum):
"""ereuse.org Battery technology with translated values from
the Linux Kernel convention, from
https://www.kernel.org/doc/Documentation/ABI/testing/sysfs-class-power.
"""
LiIon = 'Li-ion'
NiCd = 'NiCd'
NiMH = 'NiMH'
LiPoly = 'Li-poly'
LiFe = 'LiFe'
LiMn = 'LiMn'
PRE = 'POWER_SUPPLY_'
@classmethod
def new(cls, lshw, hwinfo, **kwargs) -> Iterator[C]:
try:
# uevent = cmd.run(
# 'cat', '/sys/class/power_supply/BAT*/uevent', shell=True
# ).stdout.splitlines()
return
except CalledProcessError:
return
# yield cls(uevent)
def __init__(self, node: List[str]) -> None:
super().__init__(node)
try:
self.serial_number = g.kv(
node, self.PRE + 'SERIAL_NUMBER', sep='=', type=str
)
self.manufacturer = g.kv(node, self.PRE + 'MANUFACTURER', sep='=')
self.model = g.kv(node, self.PRE + 'MODEL_NAME', sep='=')
self.size = g.kv(node, self.PRE + 'CHARGE_FULL_DESIGN', sep='=', default=0)
if self.size is not None:
self.size = self.size // 1000
self.technology = g.kv(
node, self.PRE + 'TECHNOLOGY', sep='=', type=self.Technology
)
measure = MeasureBattery(
size=g.kv(node, self.PRE + 'CHARGE_FULL', sep='='),
voltage=g.kv(node, self.PRE + 'VOLTAGE_NOW', sep='='),
cycle_count=g.kv(node, self.PRE + 'CYCLE_COUNT', sep='='),
)
try:
measure.size = measure.size.m
measure.voltage = measure.voltage.m
except AttributeError:
pass
self.actions.add(measure)
self._wear = (
round(1 - measure.size / self.size, 2)
if self.size and measure.size
else None
)
self._node = node
except NoBatteryInfo:
self._node = None
def __str__(self) -> str:
try:
return '{0} {1.technology}. Size: {1.size} Wear: {1._wear:%}'.format(
super().__str__(), self
)
except TypeError:
return 'There is not currently battery information'
class Computer(Device): class Computer(Device):
CHASSIS_TYPE = { CHASSIS_TYPE = {
'Desktop': { 'Desktop': {
@ -573,7 +502,6 @@ class Computer(Device):
COMPONENTS = list(Component.__subclasses__()) # type: List[Type[Component]] COMPONENTS = list(Component.__subclasses__()) # type: List[Type[Component]]
COMPONENTS.remove(Motherboard) COMPONENTS.remove(Motherboard)
COMPONENTS.remove(Battery)
def __init__(self, node: dict) -> None: def __init__(self, node: dict) -> None:
super().__init__(node) super().__init__(node)
@ -616,7 +544,3 @@ class Computer(Device):
def __str__(self) -> str: def __str__(self) -> str:
specs = super().__str__() specs = super().__str__()
return '{} with {} MB of RAM.'.format(specs, self._ram) return '{} with {} MB of RAM.'.format(specs, self._ram)
class NoBatteryInfo(Exception):
print('Cannot get battery information')

@ -1 +0,0 @@
Subproject commit 492dca0eeff5279b53e5dcfbedd333dc5739f1d7