Skip to content

Conversation

@JanZachmann
Copy link
Contributor

@JanZachmann JanZachmann commented Jan 14, 2026

Summary

Fixes the issue where the network rollback notification incorrectly reappears on subsequent logins after being acknowledged.

Changes

  • Extended unauth_post! macro with Pattern 0 for simple POST without body
  • Changed handle_ack_rollback to use unauth_post! instead of auth_post!
  • Improved error handling in clear_rollback_occurred with proper logging
  • Added E2E test to verify fix

Root Cause

The rollback dialog appears before login (in App.vue onMounted), so no auth token was available when clicking OK. This caused the /ack-rollback request to silently fail, leaving the backend marker file in place.

Signed-off-by: Jan Zachmann <50990105+JanZachmann@users.noreply.github.com>
Signed-off-by: Jan Zachmann <50990105+JanZachmann@users.noreply.github.com>
Signed-off-by: Jan Zachmann <50990105+JanZachmann@users.noreply.github.com>
- Implemented auth.spec.ts, device.spec.ts, network.spec.ts
- Added centrifugo fixture helper
- Fixed Centrifugo subscription in App.vue
- Improved test scripts for argument forwarding
- Configured playwright to ignore HTTPS errors
- Added jsonwebtoken for test token generation

Signed-off-by: Jan Zachmann <50990105+JanZachmann@users.noreply.github.com>
Add comprehensive unit tests for NetworkConfigService covering:
- Request validation (DHCP, static IP, netmask boundaries)
- INI file generation for systemd-networkd
- Rollback response structure
- camelCase serialization/deserialization
- enable_rollback field handling

Tests use tempfile for filesystem operations and replicate
production INI generation logic in isolation.

Note: Rollback file I/O tests not included due to hardcoded
paths (/network/, /tmp/). Would require path injection refactor.

14 tests added, bringing total backend tests from 40 to 54.

Signed-off-by: Jan Zachmann <50990105+JanZachmann@users.noreply.github.com>
Expand firmware service test coverage to validate file operations
and device service delegation:
- clear_data_folder removes files, preserves subdirectories
- load_update forwards requests to device service client
- run_update forwards requests with validation flag

Tests use mockall to mock DeviceServiceClient for async operations.

Note: clear_data_folder tests share temp directory and may race
in parallel. Run with --test-threads=1 if flaky.

7 tests total (6 new), bringing backend tests from 54 to 60.

Signed-off-by: Jan Zachmann <50990105+JanZachmann@users.noreply.github.com>
Add comprehensive unit tests for OmnectDeviceServiceClient covering:
- URL building and path normalization
- Semver version requirement parsing and matching
- Version mismatch detection for healthcheck
- Publish endpoint state tracking
- API endpoint constants validation

Tests validate client logic without requiring actual HTTP calls
or Unix socket connections.

15 tests added, bringing total backend tests from 60 to 75.

Signed-off-by: Jan Zachmann <50990105+JanZachmann@users.noreply.github.com>
…-client-tests

Signed-off-by: Jan Zachmann <50990105+JanZachmann@users.noreply.github.com>
The rollback notification was incorrectly reappearing on subsequent
logins even after the user acknowledged it. This occurred because
the acknowledgment request required authentication, but the rollback
dialog appears before login (in App.vue onMounted), so no auth token
was available. This caused the /ack-rollback POST to silently fail.

Changes:
- Extended unauth_post! macro with Pattern 0 for simple POST without body
- Refactored handle_ack_rollback to use unauth_post! instead of auth_post!
- Improved error handling in clear_rollback_occurred with proper logging
- Added E2E test to verify rollback status is cleared and doesn't reappear

The fix allows the rollback acknowledgment to work correctly before login,
ensuring the backend marker file is properly cleared.

Signed-off-by: Jan Zachmann <50990105+JanZachmann@users.noreply.github.com>
@JanZachmann JanZachmann merged commit 12beb1e into omnect:main Jan 14, 2026
3 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant