Skip to content

Commit

Permalink
feat: Add --dry-run option
Browse files Browse the repository at this point in the history
  • Loading branch information
janw committed Feb 9, 2024
1 parent 2965697 commit a73c008
Show file tree
Hide file tree
Showing 7 changed files with 95 additions and 19 deletions.
7 changes: 6 additions & 1 deletion .github/workflows/tests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -82,9 +82,14 @@ jobs:
--template brew/template.rb.j2 \
--output "$(brew --repo janw/testing)/Formula/podcast-archiver.rb"
- name: Replace head main branch
run: |
BRANCH=${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}}
sed -i'' "s/main/$BRANCH/g" "$(brew --repo janw/testing)/Formula/podcast-archiver.rb"
- name: Install formula
shell: bash
run: brew install podcast-archiver
run: brew install --HEAD podcast-archiver

- name: Test formula
shell: bash
Expand Down
2 changes: 2 additions & 0 deletions brew/template.rb.j2
Original file line number Diff line number Diff line change
Expand Up @@ -29,5 +29,7 @@ class {{ formula_name }} < Formula

test do
assert_match "podcast-archiver, ", shell_output(bin/"podcast-archiver --version")

system bin/"podcast-archiver", "--max-episodes=3", "--dry-run", "--feed=https://feeds.metaebene.me/lautsprecher/m4a"
end
end
10 changes: 10 additions & 0 deletions podcast_archiver/cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
"--filename-template",
"--write-info-json",
"--slugify",
"--dry-run",
],
},
{
Expand Down Expand Up @@ -181,6 +182,15 @@ def generate_default_config(ctx: click.Context, param: click.Parameter, value: b
show_envvar=True,
help=Settings.model_fields["quiet"].description,
)
@click.option(
"-n",
"--dry-run",
type=bool,
default=DEFAULT_SETTINGS.dry_run,
is_flag=True,
show_envvar=True,
help=Settings.model_fields["dry_run"].description,
)
@click.option(
"-C",
"--concurrency",
Expand Down
6 changes: 6 additions & 0 deletions podcast_archiver/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,12 @@ class Settings(BaseModel):
description="Print only minimal progress information. Errors will always be emitted.",
)

dry_run: bool = Field(
default=False,
alias="dry_run",
description="Do not download anything.",
)

verbose: int = Field(
default=0,
alias="verbose",
Expand Down
61 changes: 60 additions & 1 deletion podcast_archiver/console.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,62 @@
from rich.console import Console
from typing import TYPE_CHECKING

from rich import progress, table
from rich.console import Console, RenderableType

console = Console()

if TYPE_CHECKING:
_MixinBase = progress.ProgressColumn
else:
_MixinBase = object


class HideableColumnMixin(_MixinBase):
def __call__(self, task: progress.Task) -> RenderableType:
speed = task.finished_speed or task.speed
if speed is None:
return ""
return super().__call__(task)

Check warning on line 19 in podcast_archiver/console.py

View check run for this annotation

Codecov / codecov/patch

podcast_archiver/console.py#L19

Added line #L19 was not covered by tests


class HideableTimeRemainingColumn(HideableColumnMixin, progress.TimeRemainingColumn):
pass


class HideableTransferSpeedColumn(HideableColumnMixin, progress.TransferSpeedColumn):
pass


COMMON_PROGRESS_COLUMNS: list[progress.ProgressColumn] = [
progress.SpinnerColumn(finished_text="[bar.finished]✔[/]"),
progress.TextColumn(
"{task.fields[date]:%Y-%m-%d}",
style="blue",
table_column=table.Column(width=len("2023-09-24")),
),
progress.TextColumn(
"{task.description}",
style="progress.description",
table_column=table.Column(no_wrap=True, ratio=2),
),
progress.BarColumn(bar_width=25),
progress.TaskProgressColumn(),
progress.DownloadColumn(),
]

TRANSFER_COLUMNS: list[progress.ProgressColumn] = [
HideableTimeRemainingColumn(),
HideableTransferSpeedColumn(),
]


def get_progress(console: Console, dry_run: bool, disable: bool) -> progress.Progress:
cols = COMMON_PROGRESS_COLUMNS
if dry_run:
cols += [progress.TextColumn("[bright_black]\\[dry-run][/]")]

Check warning on line 56 in podcast_archiver/console.py

View check run for this annotation

Codecov / codecov/patch

podcast_archiver/console.py#L56

Added line #L56 was not covered by tests
else:
cols += TRANSFER_COLUMNS

prog = progress.Progress(*cols, console=console, expand=True, disable=disable)
prog.live.vertical_overflow = "visible"
return prog
10 changes: 8 additions & 2 deletions podcast_archiver/download.py
Original file line number Diff line number Diff line change
Expand Up @@ -60,8 +60,9 @@ def __call__(self) -> DownloadResult:
return DownloadResult.FAILED

def run(self) -> DownloadResult:
self.target.parent.mkdir(parents=True, exist_ok=True)
self.write_info_json()
if not self.settings.dry_run:
self.target.parent.mkdir(parents=True, exist_ok=True)
self.write_info_json()
if result := self.preflight_check():
return result

Expand All @@ -75,6 +76,11 @@ def run(self) -> DownloadResult:
total_size = int(response.headers.get("content-length", "0"))
self.update_progress(total=total_size)

if self.settings.dry_run:
logger.info("Dry-run download of %s", self.target)
self.update_progress(total=total_size, completed=total_size)
return DownloadResult.COMPLETED_SUCCESSFULLY

Check warning on line 82 in podcast_archiver/download.py

View check run for this annotation

Codecov / codecov/patch

podcast_archiver/download.py#L80-L82

Added lines #L80 - L82 were not covered by tests

with atomic_write(self.target, mode="wb") as fp:
receive_complete = self.receive_data(fp, response)

Expand Down
18 changes: 3 additions & 15 deletions podcast_archiver/processor.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,23 +9,12 @@
from rich import progress as rich_progress

from podcast_archiver.config import Settings
from podcast_archiver.console import console
from podcast_archiver.console import console, get_progress
from podcast_archiver.download import DownloadJob
from podcast_archiver.enums import DownloadResult, QueueCompletionType
from podcast_archiver.logging import logger
from podcast_archiver.models import Feed

PROGRESS_COLUMNS = (
rich_progress.SpinnerColumn(finished_text="[bar.finished]✔[/]"),
rich_progress.TextColumn("[blue]{task.fields[date]:%Y-%m-%d}"),
rich_progress.TextColumn("[progress.description]{task.description}"),
rich_progress.BarColumn(bar_width=25),
rich_progress.TaskProgressColumn(),
rich_progress.TimeRemainingColumn(),
rich_progress.DownloadColumn(),
rich_progress.TransferSpeedColumn(),
)


@dataclass
class ProcessingResult:
Expand All @@ -44,12 +33,11 @@ class FeedProcessor:
def __init__(self, settings: Settings) -> None:
self.settings = settings
self.pool_executor = ThreadPoolExecutor(max_workers=self.settings.concurrency)
self.progress = rich_progress.Progress(
*PROGRESS_COLUMNS,
self.progress = get_progress(
console=console,
disable=settings.verbose > 1 or settings.quiet,
dry_run=settings.dry_run,
)
# self.progress.live.vertical_overflow = "visible"
self.stop_event = Event()

def process(self, url: AnyHttpUrl) -> ProcessingResult:
Expand Down

0 comments on commit a73c008

Please sign in to comment.