Commit 189d5675 by Vik Paruchuri

gitignore working

parent 7a7a7edf
<component name="InspectionProjectProfileManager">
<settings>
<option name="PROJECT_PROFILE" />
<option name="USE_PROJECT_PROFILE" value="false" />
<version value="1.0" />
</settings>
</component>
\ No newline at end of file
<component name="DependencyValidationManager">
<state>
<option name="SKIP_IMPORT_STATEMENTS" value="false" />
</state>
</component>
\ No newline at end of file
This source diff could not be displayed because it is too large. You can view the blob instead.
#!/usr/bin/python
#------------------------------------------------------------
# Run me with (may need su privilege for logging):
# gunicorn -w 4 -b 127.0.0.1:3031 pyxserver_wsgi:application
#------------------------------------------------------------
import cgi # for the escape() function
import json
import logging
import os
import os.path
import sys
from time import localtime, strftime
script_dir = os.path.dirname(__file__)
sys.path.append(script_dir)
import settings # Not django, but do something similar
# make sure we can find the grader files
sys.path.append(settings.GRADER_ROOT)
import grade
results_template = """
<div class="test">
<header>Test results</header>
<section>
<div class="shortform">
{status}
</div>
<div class="longform">
{errors}
{results}
</div>
</section>
</div>
"""
results_correct_template = """
<div class="result-output result-correct">
<h4>{short-description}</h4>
<p>{long-description}</p>
<dl>
<dt>Output:</dt>
<dd class="result-actual-output">
<pre>{actual-output}</pre>
</dd>
</dl>
</div>
"""
results_incorrect_template = """
<div class="result-output result-incorrect">
<h4>{short-description}</h4>
<p>{long-description}</p>
<dl>
<dt>Your output:</dt>
<dd class="result-actual-output"><pre>{actual-output}</pre></dd>
<dt>Correct output:</dt>
<dd><pre>{expected-output}</pre></dd>
</dl>
</div>
"""
def format_errors(errors):
esc = cgi.escape
error_string = ''
error_list = [esc(e) for e in errors or []]
if error_list:
items = '\n'.join(['<li><pre>{0}</pre></li>\n'.format(e) for e in error_list])
error_string = '<ul>\n{0}</ul>\n'.format(items)
error_string = '<div class="result-errors">{0}</div>'.format(error_string)
return error_string
def to_dict(result):
# long description may or may not be provided. If not, don't display it.
# TODO: replace with mako template
esc = cgi.escape
if result[1]:
long_desc = '<p>{0}</p>'.format(esc(result[1]))
else:
long_desc = ''
return {'short-description': esc(result[0]),
'long-description': long_desc,
'correct': result[2], # Boolean; don't escape.
'expected-output': esc(result[3]),
'actual-output': esc(result[4])
}
def render_results(results):
output = []
test_results = [to_dict(r) for r in results['tests']]
for result in test_results:
if result['correct']:
template = results_correct_template
else:
template = results_incorrect_template
output += template.format(**result)
errors = format_errors(results['errors'])
status = 'INCORRECT'
if errors:
status = 'ERROR'
elif results['correct']:
status = 'CORRECT'
return results_template.format(status=status,
errors=errors,
results=''.join(output))
def do_GET(data):
return "Hey, the time is %s" % strftime("%a, %d %b %Y %H:%M:%S", localtime())
def do_POST(data):
# This server expects jobs to be pushed to it from the queue
xpackage = json.loads(data)
body = xpackage['xqueue_body']
# Delivery from the lms
body = json.loads(body)
student_response = body['student_response']
payload = body['grader_payload']
try:
grader_config = json.loads(payload)
except ValueError as err:
# If parsing json fails, erroring is fine--something is wrong in the content.
# However, for debugging, still want to see what the problem is
raise
relative_grader_path = grader_config['grader']
grader_path = os.path.join(settings.GRADER_ROOT, relative_grader_path)
results = grade.grade(grader_path, student_response)
# Make valid JSON message
reply = { 'correct': results['correct'],
'score': results['score'],
'msg': render_results(results) }
return json.dumps(reply)
# Entry point
def application(env, start_response):
# Handle request
method = env['REQUEST_METHOD']
data = env['wsgi.input'].read()
def post_wrapper(data):
try:
return do_POST(data)
except:
return None
handlers = {'GET': do_GET,
'POST': post_wrapper,
}
if method in handlers.keys():
reply = handlers[method](data)
if reply is not None:
start_response('200 OK', [('Content-Type', 'text/html')])
return reply
# If we fell through to here, complain.
start_response('404 Not Found', [('Content-Type', 'text/plain')])
return ''
#!/usr/bin/env python
"""Helper script to run a command on sandbox50"""
import json
import logging
import requests
import os
import os.path
import sys
import time
import settings
run_url = None
log = logging.getLogger(__name__)
def upload(paths):
"""
Given a list of paths, upload them to the sandbox, and return an id that
identifies the created directory.
"""
files = dict( (os.path.basename(f), open(f)) for f in paths)
return upload_files(files)
def upload_files(files):
endpoint = settings.RUN_URL + 'upload'
r = requests.post(endpoint, files=files)
if r.status_code != requests.codes.ok:
log.error("Request error: {0}".format(r.text))
return None
if r.json is None:
log.error("sandbox50 /upload failed to return valid json. Response:" + r.text)
return None
id = r.json.get('id')
log.debug('Upload_files response: ' + r.text)
return id
def run(id, cmd):
# Making run request
headers = {'content-type': 'application/json'}
run_args = {'cmd': cmd,
'sandbox': { 'homedir': id }}
endpoint = settings.RUN_URL + 'run'
r = requests.post(endpoint, headers=headers, data=json.dumps(run_args))
if r.json is None:
log.error("sandbox50 /run failed to return valid json. Response:" + r.text)
return None
return r.json
def record_suspicious_submission(msg, code_str):
"""
Record a suspicious submission:
TODO: upload to edx-studentcode-suspicious bucket on S3. For now, just
logging to avoids need for more config changes (S3 credentials, python
requirements).
"""
log.warning('Suspicious code: {0}, {1}'.format(msg, code_str))
def sb50_run_code(code):
"""
Upload passed in code file to the code exec sandbox as code.py, run it.
Return tuple (stdout, stderr), either of which may be None
"""
#print "Running code: \n{0}".format(code)
files = {'code.py': ('code.py', code)}
start = time.time()
id = upload_files(files)
# TODO: statsd
print "upload took %.03f sec" % (time.time() - start)
start = time.time()
r = run(id, '/usr/bin/python code.py')
print "run took %.03f sec" % (time.time() - start)
return r['stdout'], r['stderr']
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment