Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 8 additions & 1 deletion codechallenges/admin.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,14 @@

@admin.register(Question)
class CustomerQuestion(admin.ModelAdmin):
list_display = ("title", "body", "answer", "release_date", "expiration_date", "difficulty")
list_display = (
"title",
"body",
"answer",
"release_date",
"expiration_date",
"difficulty"
)


@admin.register(Submission)
Expand Down
13 changes: 9 additions & 4 deletions codechallenges/migrations/0004_question_difficulty.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,18 @@
class Migration(migrations.Migration):

dependencies = [
('codechallenges', '0003_submission_answer'),
("codechallenges", "0003_submission_answer"),
]

operations = [
migrations.AddField(
model_name='question',
name='difficulty',
field=models.CharField(blank=True, choices=[('e', 'easy'), ('m', 'medium'), ('h', 'hard')], max_length=1, null=True),
model_name="question",
name="difficulty",
field=models.CharField(
blank=True,
choices=[("e", "easy"), ("m", "medium"), ("h", "hard")],
max_length=1,
null=True,
),
),
]
4 changes: 3 additions & 1 deletion codechallenges/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,9 @@ class Question(models.Model):
("m", "medium"),
("h", "hard"),
),
max_length=1, null=True, blank=True,
max_length=1,
null=True,
blank=True,
)
event = models.ForeignKey(
CodeChallengeEvent, on_delete=models.CASCADE, blank=True, null=True
Expand Down
2 changes: 1 addition & 1 deletion codechallenges/serializers.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,4 +25,4 @@ class Meta:
class SubmissionSerializer(serializers.ModelSerializer):
class Meta:
model = Submission
fields = ("email", "correct", "answer", "question")
fields = ("email", "correct", "answer", "question", "attempts")
52 changes: 51 additions & 1 deletion codechallenges/tests.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,60 @@
from django.test import TestCase
from rest_framework.test import APIRequestFactory
from codechallenges.models import Question, Submission
from .views import SubmissionList

import datetime

# Create your tests here.


class SubmissionTestCase(TestCase):
def test_submission(self):
question1 = Question.objects.create(
title="Yeet",
body="Blaghjdklahgjfkl",
format="t",
answer="Yote",
release_date=datetime.date.today(),
expiration_date=datetime.date(2022, 4, 29),
difficulty="e",
)
factory = APIRequestFactory()

# Makes and verifies successful request (first attempt)
attempt1 = factory.post(
"/api/codechallenges/submissions/",
{
"email": "robertbabaev@cmail.carleton.ca",
"question": 1,
"answer": "Yate",
},
format="json",
)
response = SubmissionList(attempt1)
self.assertEquals(response.status_code, 201)

# Verifies submission creation
submissions = list(Submission.objects.all())
self.assertEquals(submissions[0].attempts, 1)

# Makes and verifies successful request (second attempt)
attempt2 = factory.post(
"/api/codechallenges/submissions/",
{
"email": "robertbabaev@cmail.carleton.ca",
"question": 1,
"answer": "Yote",
},
format="json",
)
response = SubmissionList(attempt2)
self.assertEquals(response.status_code, 200)

# Verifies submission update
submissions = list(Submission.objects.all())
self.assertEquals(submissions[0].attempts, 2)

def test_unique_together(self):
question1 = Question.objects.create(
title="Yeet",
Expand All @@ -14,6 +63,7 @@ def test_unique_together(self):
answer="Yote",
release_date=datetime.date.today(),
expiration_date=datetime.date(2022, 4, 29),
difficulty="e",
)

# Verify question 1 is created
Expand All @@ -39,7 +89,7 @@ def test_unique_together(self):
attempts=5,
)

# Verify submission 2 is created
# Verify submission 3 is created
self.assertNotEquals(submission2, None)

# This should fail due to duplicate checking
Expand Down
21 changes: 21 additions & 0 deletions codechallenges/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,27 @@ def SubmissionList(request):
except Question.DoesNotExist:
return HttpResponse(status=500)

# Need to check if submission exists before creating one
try:
submission = Submission.objects.get(
question=data["question"], email=data["email"]
)
submission.attempts += 1

if question.answer == data["answer"]:
submission.correct = True
else:
submission.correct = False

submission.answer = data["answer"]
submission.save()

serializer = SubmissionSerializer(submission)

return JsonResponse(serializer.data, status=200)
except Submission.DoesNotExist:
data["attempts"] = 1

if question.answer == data["answer"]:
data["correct"] = True
else:
Expand Down