summaryrefslogtreecommitdiff
path: root/tests/test-wttrin-additional-url-params.el
blob: bf47a329e14112a98343665f947ff6fa9bf717c8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
;;; test-wttrin-additional-url-params.el --- Tests for wttrin-additional-url-params -*- lexical-binding: t; -*-

;; Copyright (C) 2024-2026 Craig Jennings

;;; Commentary:
;; Unit tests for wttrin-additional-url-params function.
;; Tests URL parameter generation based on unit system configuration.

;;; Code:

(require 'ert)
(require 'wttrin)
(require 'testutil-wttrin)

;;; Setup and Teardown

(defun test-wttrin-additional-url-params-setup ()
  "Setup for additional-url-params tests."
  (testutil-wttrin-setup))

(defun test-wttrin-additional-url-params-teardown ()
  "Teardown for additional-url-params tests."
  (testutil-wttrin-teardown))

;;; Normal Cases

(ert-deftest test-wttrin-additional-url-params-normal-metric-system ()
  "Test URL params with metric unit system."
  (let ((wttrin-unit-system "m"))
    (should (string= "?m" (wttrin-additional-url-params)))))

(ert-deftest test-wttrin-additional-url-params-normal-uscs-system ()
  "Test URL params with USCS (imperial) unit system."
  (let ((wttrin-unit-system "u"))
    (should (string= "?u" (wttrin-additional-url-params)))))

(ert-deftest test-wttrin-additional-url-params-normal-wind-speed-meters ()
  "Test URL params with wind speed in m/s."
  (let ((wttrin-unit-system "M"))
    (should (string= "?M" (wttrin-additional-url-params)))))

;;; Boundary Cases

(ert-deftest test-wttrin-additional-url-params-boundary-nil-returns-question-mark ()
  "Test URL params when unit system is nil (default/location-based)."
  (let ((wttrin-unit-system nil))
    (should (string= "?" (wttrin-additional-url-params)))))

(ert-deftest test-wttrin-additional-url-params-boundary-empty-string ()
  "Test URL params with empty string unit system."
  (let ((wttrin-unit-system ""))
    (should (string= "?" (wttrin-additional-url-params)))))

;;; Error Cases

(ert-deftest test-wttrin-additional-url-params-error-unbound-variable ()
  "Test behavior when wttrin-unit-system is unbound (should use default nil)."
  ;; This test verifies the defcustom default value
  (let ((wttrin-unit-system nil))  ; Simulate default value
    (should (string= "?" (wttrin-additional-url-params)))))

(provide 'test-wttrin-additional-url-params)
;;; test-wttrin-additional-url-params.el ends here