diff options
author | prathamesh | 2013-07-02 13:15:24 +0530 |
---|---|---|
committer | prathamesh | 2013-07-02 13:15:24 +0530 |
commit | 37625e5c91f2bf957c6739981f7698e0d880b6ed (patch) | |
tree | 387e52fa104f9f3562dad3f7690bec7493730310 /testapp/test_server.py | |
parent | fe868c043487af8ea390165325309ad29daacc8e (diff) | |
parent | 610709c2ff35263741ca6e41c3648439806b564a (diff) | |
download | online_test-37625e5c91f2bf957c6739981f7698e0d880b6ed.tar.gz online_test-37625e5c91f2bf957c6739981f7698e0d880b6ed.tar.bz2 online_test-37625e5c91f2bf957c6739981f7698e0d880b6ed.zip |
Merge branch 'C-Cpp' of https://github.com/prathamesh920/online_test into fresh_C_Cpp
Diffstat (limited to 'testapp/test_server.py')
-rw-r--r-- | testapp/test_server.py | 115 |
1 files changed, 99 insertions, 16 deletions
diff --git a/testapp/test_server.py b/testapp/test_server.py index 0790816..f2ea84c 100644 --- a/testapp/test_server.py +++ b/testapp/test_server.py @@ -6,42 +6,124 @@ up the code server as:: """ from exam.xmlrpc_clients import code_server + def check_result(result, check='correct answer'): - if check != 'correct answer': - assert result[0] == False - else: - assert result[0] == True - if "unable to connect" in result[1].lower(): + if check != 'correct answer': + assert result[0] == False + else: + assert result[0] == True + if "unable to connect" in result[1].lower(): assert result[0], result[1] - assert check in result[1].lower(), result[1] + assert check in result[1].lower(), result[1] def test_python(): """Test if server runs Python code as expected.""" src = 'while True: pass' result = code_server.run_code(src, '', '/tmp', language="python") check_result(result, 'more than ') - src = 'x = 1' - result = code_server.run_code(src, 'assert x == 1', '/tmp', + result = code_server.run_code(src, 'assert x == 1', '/tmp', language="python") check_result(result, 'correct answer') - result = code_server.run_code(src, 'assert x == 0', '/tmp', + result = code_server.run_code(src, 'assert x == 0', '/tmp', language="python") check_result(result, 'assertionerror') src = 'abracadabra' - result = code_server.run_code(src, 'assert x == 0', '/tmp', + result = code_server.run_code(src, 'assert x == 0', '/tmp', language="python") check_result(result, 'nameerror') + +def test_c(): + """Test if server runs c code as expected.""" + src = """ + #include<stdiol.h> + int ad(int a, int b) + {return a+b;} + """ + result = code_server.run_code(src, 'c_cpp_files/main.cpp', '/tmp', language="C") + check_result(result, 'error') + + src = """ + int add(int a, int b) + {return a+b} + """ + result = code_server.run_code(src, 'c_cpp_files/main.cpp', '/tmp', language="C") + check_result(result, 'compilation error') + + src = """ + int add(int a, int b) + {while(1>0){} + return a+b;} + """ + result = code_server.run_code(src, 'c_cpp_files/main.cpp', '/tmp', language="C") + check_result(result, 'more than') + + src = """ + int add(int a, int b) + {return a+b;} + """ + result = code_server.run_code(src, 'c_cpp_files/main.cpp', '/tmp', language="C") + check_result(result, 'correct answer') + + src = """ + #include<stdio.h> + int add(int a, int b) + {printf("All Correct");} + """ + result = code_server.run_code(src, 'c_cpp_files/main.cpp', '/tmp', language="C") + check_result(result, 'incorrect') + + +def test_cpp(): + """Test if server runs c code as expected.""" + src = """ + int add(int a, int b) + { + return a+b + } + """ + result = code_server.run_code(src, 'c_cpp_files/main.cpp', '/tmp', language="C++") + check_result(result, 'compilation error') + + src = """ + int add(int a, int b) + { + return a+b; + } + """ + result = code_server.run_code(src, 'c_cpp_files/main.cpp', '/tmp', language="C++") + check_result(result, 'correct answer') + + src = """ + int dd(int a, int b) + { + return a+b; + } + """ + result = code_server.run_code(src, 'c_cpp_files/main.cpp', '/tmp', language="C++") + check_result(result, 'error') + + src = """ + int add(int a, int b) + { + while(0==0) + {} + return a+b; + } + """ + result = code_server.run_code(src, 'c_cpp_files/main.cpp', '/tmp', language="C++") + check_result(result, 'more than') + def test_bash(): """Test if server runs Bash code as expected.""" src = """ #!/bin/bash [[ $# -eq 2 ]] && echo $(( $1 + $2 )) && exit $(( $1 + $2 )) """ - result = code_server.run_code(src, + result = code_server.run_code(src, 'docs/sample.sh\ndocs/sample.args', '/tmp', language="bash") check_result(result) @@ -49,7 +131,7 @@ def test_bash(): #!/bin/bash [[ $# -eq 2 ]] && echo $(( $1 - $2 )) && exit $(( $1 - $2 )) """ - result = code_server.run_code(src, + result = code_server.run_code(src, 'docs/sample.sh\ndocs/sample.args', '/tmp', language="bash") check_result(result, 'error') @@ -57,7 +139,7 @@ def test_bash(): #!/bin/bash while [ 1 ] ; do echo "" > /dev/null ; done """ - result = code_server.run_code(src, + result = code_server.run_code(src, 'docs/sample.sh\ndocs/sample.args', '/tmp', language="bash") check_result(result, 'more than ') @@ -65,15 +147,15 @@ def test_bash(): #!/bin/bash while [ 1 ] ; do echo "" > /dev/null ''' - result = code_server.run_code(src, - 'docs/sample.sh\ndocs/sample.args', '/tmp', language="bash") + result = code_server.run_code(src, + 'docs/sample.sh\ndocs/sample.args', '/tmp', language="bash") check_result(result, 'error') src = '''# Enter your code here. #!/bin/bash while [ 1 ] ; do echo "" > /dev/null ''' - result = code_server.run_code(src, + result = code_server.run_code(src, 'docs/sample.sh\ndocs/sample.args', '/tmp', language="bash") check_result(result, 'oserror') @@ -81,3 +163,4 @@ if __name__ == '__main__': test_python() test_bash() test_c() + test_cpp() |