summaryrefslogtreecommitdiff
path: root/features/step-definitions
diff options
context:
space:
mode:
authordickmao <rchiang@cs.stonybrook.edu>2018-08-28 21:48:31 -0400
committerdickmao <dick.r.chiang@gmail.com>2018-08-30 00:14:42 -0400
commit800dd7677276f9e425c5db37b3e31e56ab1dad32 (patch)
tree09eb145ffcbaf89d873c89e8346ee8d38a88ebbe /features/step-definitions
parent5bd1e7248bb9bf3b335cbd6bec250866bd165af1 (diff)
Add tests for castling legality and ics response handling.
Fixes misinterpretation of "e1-b1" as a valid queenside castle, and makes more sense of ics basic response handling #21. `make test` should run the historic.pgn test and the new ecukes tests.
Diffstat (limited to 'features/step-definitions')
-rw-r--r--features/step-definitions/emacs-chess-steps.el47
1 files changed, 47 insertions, 0 deletions
diff --git a/features/step-definitions/emacs-chess-steps.el b/features/step-definitions/emacs-chess-steps.el
new file mode 100644
index 0000000..5e1b6cc
--- /dev/null
+++ b/features/step-definitions/emacs-chess-steps.el
@@ -0,0 +1,47 @@
+;; This file contains your project specific step definitions. All
+;; files in this directory whose names end with "-steps.el" will be
+;; loaded automatically by Ecukes.
+
+(Given "^ics session$"
+ (lambda ()
+ (let ((test-fn (expand-file-name (make-temp-name "test-fifo") (or small-temporary-file-directory temporary-file-directory))))
+ (setq test-fifo (start-process-shell-command "test-fifo" nil (format "mkfifo %s && cat >> %s" test-fn test-fn)))
+ (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)
+ (chess-ics "nowhere.org" 5000 nil nil "sh" "-c" (format "cat %s" test-fn))
+
+ )))
+
+(When "^new game$"
+ (lambda ()
+ (process-send-string test-fifo (format "{Game 42 (GuestYOU vs. GuestME) Creating unrated blitz match.}\n"))
+ (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)
+ )
+ )
+
+(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)
+ ))
+
+(Given "^game with fen \"\\(.+\\)\"$"
+ (lambda (fen)
+ (let ((game (chess-game-create (chess-fen-to-pos fen))) objects)
+ (setq test-display (car (chess-create-modules (list '(chess-plain))
+ 'chess--create-display
+ game t t))))))
+
+(Then "^the move \"\\([a-h][1-8]\\)-\\([a-h][1-8]\\)\" is illegal$"
+ (lambda (source target)
+ (let ((position (chess-display-position test-display)))
+ (assert (null (chess-ply-create position nil
+ (chess-coord-to-index source)
+ (chess-coord-to-index target)))))))
+
+