mirror of
https://github.com/home-assistant/core.git
synced 2026-02-24 11:57:05 +00:00
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com> Co-authored-by: Franck Nijhof <git@frenck.dev>
109 lines
4.2 KiB
Python
109 lines
4.2 KiB
Python
"""Tests for scrape component."""
|
|
|
|
from __future__ import annotations
|
|
|
|
from typing import Any
|
|
|
|
|
|
def return_integration_config(
|
|
*,
|
|
authentication=None,
|
|
username=None,
|
|
password=None,
|
|
headers=None,
|
|
sensors=None,
|
|
) -> dict[str, dict[str, Any]]:
|
|
"""Return config."""
|
|
config = {
|
|
"resource": "https://www.home-assistant.io",
|
|
"verify_ssl": True,
|
|
"sensor": sensors,
|
|
}
|
|
if authentication:
|
|
config["authentication"] = authentication
|
|
if username:
|
|
config["username"] = username
|
|
config["password"] = password
|
|
if headers:
|
|
config["headers"] = headers
|
|
|
|
return config
|
|
|
|
|
|
class MockRestData:
|
|
"""Mock RestData."""
|
|
|
|
def __init__(
|
|
self,
|
|
payload,
|
|
) -> None:
|
|
"""Init RestDataMock."""
|
|
self.data: str | None = None
|
|
self.headers: dict[str, str] | None = None
|
|
self.payload = payload
|
|
self.count = 0
|
|
|
|
async def async_update(self, data: bool | None = True) -> None:
|
|
"""Update."""
|
|
self.count += 1
|
|
self.headers = {}
|
|
if self.payload == "test_scrape_sensor":
|
|
self.data = (
|
|
# Default
|
|
"<div class='current-version material-card text'>"
|
|
"<h1>Current Version: 2021.12.10</h1>Released: <span class='release-date'>January 17, 2022</span>"
|
|
"<div class='links' style='links'><a href='/latest-release-notes/'>Release notes</a></div></div>"
|
|
"<template>Trying to get</template>"
|
|
"<div class='current-time'>"
|
|
"<h1>Current Time:</h1><span class='utc-time'>2022-12-22T13:15:30Z</span>"
|
|
"</div>"
|
|
)
|
|
if self.payload == "test_scrape_sensor2":
|
|
self.data = (
|
|
# Hidden version
|
|
"<div class='current-version material-card text'>"
|
|
"<h1>Hidden Version: 2021.12.10</h1>Released: <span class='release-date'>January 17, 2022</span>"
|
|
"<div class='links' style='links'><a href='/latest-release-notes/'>Release notes</a></div></div>"
|
|
"<template>Trying to get</template>"
|
|
)
|
|
if self.payload == "test_scrape_uom_and_classes":
|
|
self.data = (
|
|
"<div class='current-temp temp-card text'>"
|
|
"<h3>Current Temperature: 22.1</h3>"
|
|
"<div class='links'><a href='/check_temp/'>Temp check</a></div></div>"
|
|
)
|
|
if self.payload == "test_scrape_sensor_authentication":
|
|
self.data = "<div class='return'>secret text</div>"
|
|
if self.payload == "test_scrape_sensor_no_data":
|
|
self.data = None
|
|
if self.payload == "test_scrape_xml":
|
|
# XML/RSS content for testing XML parser detection via Content-Type
|
|
self.headers = {"Content-Type": "application/rss+xml"}
|
|
self.data = (
|
|
'<?xml version="1.0" encoding="UTF-8"?>'
|
|
"<rss><channel><title>Test RSS Feed</title>"
|
|
"<item><title>Test Item</title><link>https://example.com/item</link></item>"
|
|
"</channel></rss>"
|
|
)
|
|
if self.payload == "test_scrape_xml_fallback":
|
|
# XML/RSS content with non-XML Content-Type for testing content-based detection
|
|
self.headers = {"Content-Type": "text/html"}
|
|
self.data = (
|
|
'<?xml version="1.0" encoding="UTF-8"?>'
|
|
"<rss><channel><title>Test RSS Feed</title>"
|
|
"<item><title>Test Item</title><link>https://example.com/item</link></item>"
|
|
"</channel></rss>"
|
|
)
|
|
if self.payload == "test_scrape_html5_with_xml_declaration":
|
|
# HTML5 with XML declaration, no Content-Type header, and uppercase tags
|
|
# Tests: XML stripping, content detection, case-insensitive selectors
|
|
self.data = (
|
|
'<?xml version="1.0" encoding="UTF-8"?>\n'
|
|
"<!DOCTYPE html>\n"
|
|
"<html><head><TITLE>Test Page</TITLE></head>"
|
|
"<body><DIV class='current-version'>"
|
|
"<H1>Current Version: 2021.12.10</H1></DIV></body></html>"
|
|
)
|
|
if self.count == 3:
|
|
self.data = None
|