aboutsummaryrefslogtreecommitdiff
path: root/tests/tcpvanilla
diff options
context:
space:
mode:
authorIbrahim Mkusa <ibrahimmkusa@gmail.com>2017-04-14 09:57:40 -0400
committerIbrahim Mkusa <ibrahimmkusa@gmail.com>2017-04-14 09:57:40 -0400
commite09975a02c24c53a6b8c4a704b74236945c3fdcc (patch)
treef53e8144f79d2486fafc0b06604708da27fca768 /tests/tcpvanilla
parentfd2488cf59f0f19ee0e09ca4792fc2262bc4708e (diff)
tidied up
Diffstat (limited to 'tests/tcpvanilla')
-rw-r--r--tests/tcpvanilla/tcpcommunication.rkt60
1 files changed, 60 insertions, 0 deletions
diff --git a/tests/tcpvanilla/tcpcommunication.rkt b/tests/tcpvanilla/tcpcommunication.rkt
new file mode 100644
index 0000000..134e697
--- /dev/null
+++ b/tests/tcpvanilla/tcpcommunication.rkt
@@ -0,0 +1,60 @@
+#lang racket
+;; Reads input iteratively then sends it to local server
+;; client reads back the message and displays it
+
+(require math/base) ;; for random number generation
+
+(define listener (tcp-listen 4326 5 #t))
+(define a (thread (lambda ()
+ (define-values (s-in s-out) (tcp-accept listener))
+ ; Discard the request header (up to blank line):
+ ;(regexp-match #rx"(\r\n|^)\r\n" s-in)
+ (sleep 10)
+ (define (echo)
+ (define input (read-line s-in))
+ (displayln input s-out)
+ (flush-output s-out)
+ (if (eof-object? input)
+ (displayln "Done talking\n")
+ (echo)))
+ (echo)
+ (close-input-port s-in)
+ (close-output-port s-out)
+ (tcp-close listener)
+ 'ok)))
+
+(define t (thread (lambda ()
+ (define-values (c-in c-out) (tcp-connect "localhost" 4326))
+ (define input-prompt "input: ")
+ (define output-prompt "output: ")
+
+ ;; prompt for username and bind to a variable username
+ (display "What's your name?\n")
+ (define username (read-line))
+ (define usernamei (string-append username ": ")) ;; make username appear nicer in a prompt
+ (define fair (make-semaphore 1))
+
+ ;; intelligent read, quits when user types in "quit"
+ (define (read-loop-i)
+ ;(semaphore-wait fair)
+ ; (display usernamei)
+ (define input (read-line))
+ ;; do something over here with input maybe send it out
+
+ ;; Tests input if its a quit then kills all threads
+ ;; An if would be better here tbh
+ (cond ((string=? input "quit") (exit)))
+ (display (string-append output-prompt input "\n") c-out)
+ (flush-output c-out)
+ (displayln (read-line c-in)) ;; server echoes back sent input
+ ;(semaphore-post fair)
+ (read-loop-i)
+ )
+ (read-loop-i)
+ 'ok)))
+
+;(kill-thread a)
+;(kill-thread t)
+(thread-wait t)
+(display "DONE!!\n")
+