diff options
| author | dickmao <dick.r.chiang@gmail.com> | 2018-08-27 17:00:35 -0400 | 
|---|---|---|
| committer | dickmao <dick.r.chiang@gmail.com> | 2018-09-06 09:24:10 -0400 | 
| commit | 3222b53d942daa404852e5148ba9d3ebb8fe96d0 (patch) | |
| tree | 37e2af6242423e57adbbc1238433f58c92ac9bd0 /features/step-definitions/emacs-chess-steps.el | |
| parent | 67339d896aa65d75272b80134a8128276c8c6a0f (diff) | |
Pre-moves
To activate, look for Chess Display Allow Pre Moves in:
M-x customize-group
chess-display
Tested via:
make test
make test24 (requires evim)
Diffstat (limited to 'features/step-definitions/emacs-chess-steps.el')
| -rw-r--r-- | features/step-definitions/emacs-chess-steps.el | 146 | 
1 files changed, 143 insertions, 3 deletions
| diff --git a/features/step-definitions/emacs-chess-steps.el b/features/step-definitions/emacs-chess-steps.el index 5e1b6cc..b0d2ae0 100644 --- a/features/step-definitions/emacs-chess-steps.el +++ b/features/step-definitions/emacs-chess-steps.el @@ -9,7 +9,7 @@             (process-send-string test-fifo "login:\n")             (process-send-string test-fifo "Logging you in as \"GuestME\"\n")             (process-send-string test-fifo "fics% \n") -           (sleep-for 3) +           (sleep-for 2)             (chess-ics "nowhere.org" 5000 nil nil "sh" "-c" (format "cat %s" test-fn))         ))) @@ -20,16 +20,35 @@          (process-send-string test-fifo (format "<12> rnbqkbnr pppppppp -------- -------- -------- -------- PPPPPPPP RNBQKBNR W -1 1 1 1 1 0 23 GuestYOU GuestME -1 5 5 39 39 300 300 1 none (0:00) none 1 0 0\n"))          (process-send-string test-fifo (format "<12> rnbqkbnr pppppppp -------- -------- --P----- -------- PP-PPPPP RNBQKBNR B 2 1 1 1 1 0 23 GuestYOU GuestME 1 5 5 39 39 300 300 1 P/c2-c4 (0:00) c4 1 0 0\n"))          (process-send-string test-fifo (format "<12> rnbqkbnr pppp-ppp -------- ----p--- --P----- -------- PP-PPPPP RNBQKBNR W 4 1 1 1 1 0 23 GuestYOU GuestME -1 5 5 39 39 300 300 2 P/e7-e5 (0:00) e5 1 1 0\n")) -        (sleep-for 3) +        (sleep-for 2)          )        )  (When "^opponent forfeits on time$"        (lambda ()          (process-send-string test-fifo (format "{Game 42 (GuestYOU vs. GuestME) GuestYOU forfeits on time} 0-1\n")) -        (sleep-for 3) +        (sleep-for 2)          )) +(When "^opponent forfeits by disconnection$" +      (lambda () +        (process-send-string test-fifo (format "{Game 42 (GuestYOU vs. GuestME) GuestYOU forfeits by disconnection} 1-0\n")) +        (sleep-for 2) +        )) + +(When "^opponent aborts$" +      (lambda () +        (process-send-string test-fifo (format "Your opponent has aborted the game on move one.\n")) +        (sleep-for 2) +        )) + +(When "^I specify a good port$" +      (lambda () +        (if espuds-chain-active +            (progn +              (setq espuds-action-chain (vconcat espuds-action-chain (string-to-vector test-port)))) +          (execute-kbd-macro (string-to-vector test-port))))) +  (Given "^game with fen \"\\(.+\\)\"$"         (lambda (fen)           (let ((game (chess-game-create (chess-fen-to-pos fen))) objects) @@ -37,6 +56,22 @@                                                           'chess--create-display                                                           game t t)))))) +(When "^I set position of \"\\(.+\\)\" to fen \"\\(.+\\)\"$" +      (lambda (process-name fen) +        (chess-with-current-buffer (process-buffer (get-process process-name)) +          (chess-engine-set-position nil (chess-fen-to-pos fen))) +        (sleep-for 2) +)) + + +(When "^I send position from \"\\(.+\\)\"$" +      (lambda (process-name) +        (chess-with-current-buffer (process-buffer (get-process process-name)) +          (chess-game-run-hooks chess-module-game 'setup-pos (chess-game-pos chess-module-game))) +        (sleep-for 2) +)) + +  (Then "^the move \"\\([a-h][1-8]\\)-\\([a-h][1-8]\\)\" is illegal$"        (lambda (source target)          (let ((position (chess-display-position test-display))) @@ -44,4 +79,109 @@                                            (chess-coord-to-index source)                                            (chess-coord-to-index target))))))) +(Then "^I am ready to play$" +      (lambda () +        (let ((ready (apply 'chess-string 'opp-ready (list user-full-name)))) +          (Then "I should see message \"%s\"" ready)))) + +(When "^\\(white\\|black\\) moves \"\\(.+\\)\"$" +      (lambda (color move) +        (if (string= "white" color) +            (Given "I switch to buffer \"*Chessboard*\"") +          (Given "I switch to buffer \"*Chessboard*<2>\"")) +        (When "I type \"%s\"" move) +        (sleep-for 1) +)) + +(When "^\\(white\\|black\\) selects \"\\([a-h][1-8]\\)\"$" +      (lambda (color source) +        (if (string= "white" color) +            (Given "I switch to buffer \"*Chessboard*\"") +          (Given "I switch to buffer \"*Chessboard*<2>\"")) +        (When "I go to point \"%s\"" (number-to-string (chess-display-index-pos nil (chess-coord-to-index source)))) +        (When "I press \"RET\"") +        (sleep-for 1) +)) + +(Then "^paint-move last \\([0-9]+\\) plies less than \\([0-9]+\\) microseconds" +      (lambda (times micros) +        (dotimes (i (string-to-number times)) +          (let ((ply (chess-game-ply chess-module-game (1- (- chess-display-index i))))) +            (assert (< (measure-time (chess-display-paint-move nil ply)) +                       (/ (string-to-number micros) 1e6))))))) + +(Given "^I start server and client$" +       (lambda () +         (Given "I start server") +         (sleep-for 1) +         (Given "I start client") +         (sleep-for 1) +         )) + +(Given "^I start server$" +       (lambda () +         (And "I start an action chain") +         (And "I press \"C-u M-x\"") +         (And "I type \"chess\"") +         (And "I press \"RET\"") +         (And "I type \"network\"") +         (And "I press \"RET\"") +         (And "I press \"s\"") +         (And "I specify a good port") +         (And "I press \"RET\"") +         (And "I execute the action chain"))) + +(Given "^I start client$" +       (lambda () +         (And "I start an action chain") +         (And "I press \"C-u M-x\"") +         (And "I type \"chess\"") +         (And "I press \"RET\"") +         (And "I type \"network\"") +         (And "I press \"RET\"") +         (And "I press \"c\"") +         (And "I type \"localhost\"") +         (And "I press \"RET\"") +         (And "I specify a good port") +         (And "I press \"RET\"") +         (And "I execute the action chain") +)) + +(Then "^the square at \"\\([a-h][1-8]\\)\" is highlighted \\(.+\\)$" +      (lambda (source kind) +        (if (display-graphic-p) +            (let ((prop (copy-alist (get-text-property  +                                     (chess-display-index-pos nil (chess-coord-to-index source)) +                                     'display)))) +              (chess-display-highlight nil  +                                       (cond ((string= kind "selected") +                                              chess-images-highlight-color) +                                             ((string= kind "pre-move") +                                              chess-display-pre-move-color) +                                             ((string= kind "last-move") +                                              chess-display-last-move-color) +                                             ((string= kind "legal") +                                              chess-display-legal-move-color) +                                             (t chess-display-last-move-color)) +                                       (chess-coord-to-index source)) +              (assert (equal prop (get-text-property  +                                   (chess-display-index-pos nil (chess-coord-to-index source)) +                                   'display)))) +          (assert (eq (get-text-property  +                       (chess-display-index-pos nil (chess-coord-to-index source)) +                       'face) (cond ((string= kind "selected") 'chess-ics1-highlight-face) +                                    (t 'chess-display-highlight))))))) +(Then "^the square at \"\\([a-h][1-8]\\)\" is unhighlighted$" +      (lambda (source) +        (if (display-graphic-p) +            (let ((prop (copy-alist (get-text-property  +                                     (chess-display-index-pos nil (chess-coord-to-index source)) +                                     'display)))) +              (chess-display-unhighlight-square nil (chess-coord-to-index source)) +              (assert (equal prop (get-text-property  +                                   (chess-display-index-pos nil (chess-coord-to-index source)) +                                   'display)))) +          (assert (not (eq (get-text-property  +                            (chess-display-index-pos nil (chess-coord-to-index source)) +                            'face) 'chess-display-highlight)))))) | 
