summaryrefslogtreecommitdiff
path: root/tests/test-wttrin--build-url.el
diff options
context:
space:
mode:
authorCraig Jennings <c@cjennings.net>2025-11-08 10:34:56 -0600
committerCraig Jennings <c@cjennings.net>2025-11-08 10:34:56 -0600
commit31649f588dbc0098b6641222403f68107819f34f (patch)
tree75c180ea2152d43504b63c2597d15e1306bda7ce /tests/test-wttrin--build-url.el
parent44d48bad4d317ce8fd9361314d349b1256e6c25b (diff)
test: core: enhance ERT tests for pure functions
- Enhanced test-wttrin-additional-url-params with clearer test organization - Enhanced test-wttrin--build-url with comprehensive boundary and error cases - Added tests for Unicode, special characters, GPS coordinates, domains - Fixed domain name test to check for URL-encoded @ symbol (%40) - Enhanced test-wttrin--make-cache-key with extensive boundary tests - Critical test: same location with different units produces different keys - Added tests for special chars, Unicode, empty strings, pipe characters All 29 tests for these three pure functions now pass (6 + 12 + 11) Combined with wttrin--fetch-url tests: 38 total tests passing
Diffstat (limited to 'tests/test-wttrin--build-url.el')
-rw-r--r--tests/test-wttrin--build-url.el143
1 files changed, 76 insertions, 67 deletions
diff --git a/tests/test-wttrin--build-url.el b/tests/test-wttrin--build-url.el
index 21d3241..87a5f92 100644
--- a/tests/test-wttrin--build-url.el
+++ b/tests/test-wttrin--build-url.el
@@ -1,91 +1,100 @@
;;; test-wttrin--build-url.el --- Tests for wttrin--build-url -*- lexical-binding: t; -*-
-;; Copyright (C) 2025 Craig Jennings
+;; Copyright (C) 2024 Craig Jennings
;;; Commentary:
-
;; Unit tests for wttrin--build-url function.
-;; Tests URL construction with proper encoding and parameters.
+;; Tests URL construction from location queries with proper encoding and parameters.
;;; Code:
(require 'ert)
(require 'wttrin)
-(require 'testutil-wttrin)
;;; Normal Cases
-(ert-deftest test-wttrin--build-url-normal-simple-location-returns-url ()
- "Test that simple location builds correct URL."
- (testutil-wttrin-with-unit-system nil
- (should (equal "https://wttr.in/Paris?A"
- (wttrin--build-url "Paris")))))
-
-(ert-deftest test-wttrin--build-url-normal-location-with-metric-returns-url ()
- "Test that location with metric unit system builds correct URL."
- (testutil-wttrin-with-unit-system "m"
- (should (equal "https://wttr.in/London?mA"
- (wttrin--build-url "London")))))
-
-(ert-deftest test-wttrin--build-url-normal-location-with-uscs-returns-url ()
- "Test that location with USCS unit system builds correct URL."
- (testutil-wttrin-with-unit-system "u"
- (should (equal "https://wttr.in/Berlin?uA"
- (wttrin--build-url "Berlin")))))
+(ert-deftest test-wttrin--build-url-normal-simple-city ()
+ "Test URL building with simple city name."
+ (let ((wttrin-unit-system nil))
+ (should (string= "https://wttr.in/Paris?A"
+ (wttrin--build-url "Paris")))))
+
+(ert-deftest test-wttrin--build-url-normal-city-with-country ()
+ "Test URL building with city and country code."
+ (let ((wttrin-unit-system nil))
+ (should (string= "https://wttr.in/London%2C%20GB?A"
+ (wttrin--build-url "London, GB")))))
+
+(ert-deftest test-wttrin--build-url-normal-metric-system ()
+ "Test URL building with metric unit system."
+ (let ((wttrin-unit-system "m"))
+ (should (string= "https://wttr.in/Tokyo?mA"
+ (wttrin--build-url "Tokyo")))))
+
+(ert-deftest test-wttrin--build-url-normal-imperial-system ()
+ "Test URL building with USCS/imperial unit system."
+ (let ((wttrin-unit-system "u"))
+ (should (string= "https://wttr.in/NewYork?uA"
+ (wttrin--build-url "NewYork")))))
;;; Boundary Cases
-(ert-deftest test-wttrin--build-url-boundary-location-with-spaces-encodes-url ()
- "Test that location with spaces is properly URL-encoded."
- (testutil-wttrin-with-unit-system nil
- (should (equal "https://wttr.in/New%20York?A"
- (wttrin--build-url "New York")))))
-
-(ert-deftest test-wttrin--build-url-boundary-location-with-comma-encodes-url ()
- "Test that location with comma is properly URL-encoded."
- (testutil-wttrin-with-unit-system nil
- (should (equal "https://wttr.in/New%20York%2C%20NY?A"
- (wttrin--build-url "New York, NY")))))
-
-(ert-deftest test-wttrin--build-url-boundary-location-with-special-chars-encodes-url ()
- "Test that location with special characters is properly URL-encoded."
- (testutil-wttrin-with-unit-system "m"
- ;; ~Eiffel+Tower format is used by wttr.in for landmarks
- ;; ~ is an unreserved character (RFC 3986) and is not encoded
- ;; + is encoded as %2B
- (should (equal "https://wttr.in/~Eiffel%2BTower?mA"
- (wttrin--build-url "~Eiffel+Tower")))))
-
-(ert-deftest test-wttrin--build-url-boundary-unicode-location-encodes-url ()
- "Test that Unicode location is properly URL-encoded."
- (testutil-wttrin-with-unit-system nil
- ;; Unicode should be properly encoded
- (let ((result (wttrin--build-url "東京")))
- (should (string-prefix-p "https://wttr.in/" result))
- (should (string-suffix-p "?A" result))
- ;; Should contain URL-encoded Unicode
- (should (string-match-p "%[0-9A-F][0-9A-F]" result)))))
-
-(ert-deftest test-wttrin--build-url-boundary-empty-location-returns-url ()
- "Test that empty location builds URL with empty query."
- (testutil-wttrin-with-unit-system nil
- (should (equal "https://wttr.in/?A"
- (wttrin--build-url "")))))
-
-(ert-deftest test-wttrin--build-url-boundary-gps-coordinates-encodes-url ()
- "Test that GPS coordinates are properly URL-encoded."
- (testutil-wttrin-with-unit-system nil
- ;; Format: -78.46,106.79
- (should (equal "https://wttr.in/-78.46%2C106.79?A"
- (wttrin--build-url "-78.46,106.79")))))
+(ert-deftest test-wttrin--build-url-boundary-unicode-city-name ()
+ "Test URL building with Unicode characters in city name."
+ (let ((wttrin-unit-system nil))
+ (let ((url (wttrin--build-url "北京"))) ; Beijing in Chinese
+ (should (string-match-p "https://wttr.in/%[0-9A-F]+.*\\?A" url))
+ (should (string-prefix-p "https://wttr.in/" url))
+ (should (string-suffix-p "?A" url)))))
+
+(ert-deftest test-wttrin--build-url-boundary-special-characters ()
+ "Test URL building with special characters requiring encoding."
+ (let ((wttrin-unit-system nil))
+ (let ((url (wttrin--build-url "São Paulo")))
+ (should (string-match-p "https://wttr.in/S%C3%A3o%20Paulo\\?A" url)))))
+
+(ert-deftest test-wttrin--build-url-boundary-spaces-encoded ()
+ "Test that spaces in query are properly URL-encoded."
+ (let ((wttrin-unit-system nil))
+ (let ((url (wttrin--build-url "New York")))
+ (should (string= "https://wttr.in/New%20York?A" url))
+ (should-not (string-match-p " " url)))))
+
+(ert-deftest test-wttrin--build-url-boundary-airport-code ()
+ "Test URL building with 3-letter airport code."
+ (let ((wttrin-unit-system nil))
+ (should (string= "https://wttr.in/SFO?A"
+ (wttrin--build-url "SFO")))))
+
+(ert-deftest test-wttrin--build-url-boundary-gps-coordinates ()
+ "Test URL building with GPS coordinates."
+ (let ((wttrin-unit-system nil))
+ (let ((url (wttrin--build-url "-78.46,106.79")))
+ (should (string-match-p "https://wttr.in/-78\\.46.*106\\.79\\?A" url)))))
+
+(ert-deftest test-wttrin--build-url-boundary-domain-name ()
+ "Test URL building with domain name (wttr.in supports @domain).
+The @ symbol should be URL-encoded as %40."
+ (let ((wttrin-unit-system nil))
+ (let ((url (wttrin--build-url "@github.com")))
+ (should (string-prefix-p "https://wttr.in/" url))
+ (should (string-match-p "%40github\\.com" url)))))
;;; Error Cases
-(ert-deftest test-wttrin--build-url-error-nil-location-signals-error ()
- "Test that nil location signals an error."
- (testutil-wttrin-with-unit-system nil
+(ert-deftest test-wttrin--build-url-error-nil-query-signals-error ()
+ "Test that nil query signals an error."
+ (let ((wttrin-unit-system nil))
(should-error (wttrin--build-url nil)
:type 'error)))
+(ert-deftest test-wttrin--build-url-error-nil-query-has-message ()
+ "Test that nil query error has descriptive message."
+ (let ((wttrin-unit-system nil))
+ (condition-case err
+ (wttrin--build-url nil)
+ (error
+ (should (string-match-p "cannot be nil" (error-message-string err)))))))
+
(provide 'test-wttrin--build-url)
;;; test-wttrin--build-url.el ends here