aboutsummaryrefslogtreecommitdiff
path: root/tests/test-eww-config-user-agent-advice.el
blob: c045a50346f94f9e9b2f883a28acbbec90dc70f5 (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
;;; test-eww-config-user-agent-advice.el --- Tests for EWW user-agent advice -*- lexical-binding: t; -*-

;;; Commentary:
;; my-eww--inject-user-agent is an :around advice on url-retrieve(-synchronously)
;; that adds a desktop User-Agent only for requests originating in an EWW
;; buffer.  These tests pin that scoping: package.el and other non-EWW URL
;; callers must pass through untouched, so the advice can't change how the
;; rest of Emacs fetches URLs.

;;; Code:

(require 'ert)
(require 'cl-lib)
(require 'eww)

(add-to-list 'load-path (expand-file-name "modules" user-emacs-directory))
(require 'eww-config)

;;; Normal Cases

(ert-deftest test-eww-ua-injected-in-eww-buffer ()
  "Normal: in an eww-mode buffer the advice adds the configured User-Agent."
  (with-temp-buffer
    (setq major-mode 'eww-mode)
    (let (seen)
      (my-eww--inject-user-agent
       (lambda (&rest _) (setq seen (assoc "User-Agent" url-request-extra-headers))))
      (should seen)
      (should (equal (cdr seen) my-eww-user-agent)))))

;;; Boundary Cases

(ert-deftest test-eww-ua-not-injected-outside-eww ()
  "Boundary: outside eww-mode (package.el, normal url fetches) no UA is added."
  (with-temp-buffer
    (fundamental-mode)
    (let ((url-request-extra-headers nil) captured)
      (my-eww--inject-user-agent
       (lambda (&rest _) (setq captured url-request-extra-headers)))
      (should (null (assoc "User-Agent" captured))))))

(ert-deftest test-eww-ua-replaces-existing-and-keeps-other-headers ()
  "Boundary: an existing User-Agent is replaced (not duplicated) and other
headers survive, when the request comes from EWW."
  (with-temp-buffer
    (setq major-mode 'eww-mode)
    (let ((url-request-extra-headers '(("User-Agent" . "old") ("Accept" . "x")))
          seen)
      (my-eww--inject-user-agent
       (lambda (&rest _) (setq seen url-request-extra-headers)))
      (should (= 1 (cl-count "User-Agent" seen :key #'car :test #'string-equal)))
      (should (equal (cdr (assoc "User-Agent" seen)) my-eww-user-agent))
      (should (assoc "Accept" seen)))))

(provide 'test-eww-config-user-agent-advice)
;;; test-eww-config-user-agent-advice.el ends here