Merge branch 'master' into lineup_as_table
This commit is contained in:
@@ -8,7 +8,7 @@
|
||||
{{ event.start|date:"l, F j, Y g:i A" }} <br>
|
||||
{{ event.venue.name }} <br>
|
||||
<a class="btn btn-primary btn-sm" href="{% url 'edit event' event.id%}" role="button">Edit Event Details</a>
|
||||
<a class="btn btn-primary btn-sm" href="{% url 'edit lineup' event.id%}" role="button">Edit Lineup</a>
|
||||
<a class="btn btn-primary btn-sm" href="{% url 'edit lineup' event_id=event.id%}" role="button">Edit Lineup</a>
|
||||
</li>
|
||||
{% endfor %}
|
||||
</ol>
|
||||
|
||||
176
events/tests.py
176
events/tests.py
@@ -1,112 +1,80 @@
|
||||
from django.test import TestCase
|
||||
from events.models import Player, Event, Availability, Team, Positioning
|
||||
import datetime
|
||||
import pytz
|
||||
# Create your tests here.
|
||||
from django.test import TestCase, Client
|
||||
from django.test.utils import setup_test_environment
|
||||
from django.urls import reverse
|
||||
from .models import Event
|
||||
from datetime import datetime
|
||||
FIXTURES = ['blaseball']
|
||||
|
||||
class BenchcoachTestCase(TestCase):
|
||||
def setUp(self):
|
||||
for first_name, last_name, jersey_number in [
|
||||
("Rush", "Valenzuela", 1),
|
||||
("Baby", "Triumphant", 2)
|
||||
]:
|
||||
Player.objects.create(first_name=first_name, last_name=last_name, jersey_number=jersey_number)
|
||||
class TestEventModel(TestCase):
|
||||
fixtures = FIXTURES
|
||||
|
||||
for name in ["Firefighters", "Garages"]:
|
||||
Team.objects.create(name=name)
|
||||
def test_query_event(self):
|
||||
"""
|
||||
Return the desired event
|
||||
"""
|
||||
event = Event.objects.get(id=1)
|
||||
self.assertEqual("Chicago Firefighters", event.away_team.name)
|
||||
self.assertEqual("Dallas Steaks", event.home_team.name)
|
||||
self.assertEqual('George Fourman Stadium', event.venue.name)
|
||||
self.assertEqual(datetime(
|
||||
year=2020,
|
||||
month=8,
|
||||
day=24,
|
||||
hour=16,
|
||||
minute=0,
|
||||
second=1), event.start)
|
||||
|
||||
for start, home_team_id, away_team_id in [
|
||||
(datetime.datetime(2020, 1, 2, 12, 0), 1, 2), # id = 1
|
||||
(datetime.datetime(2020, 1, 3, 12, 0), 2, 1), # id = 2
|
||||
(datetime.datetime(2020, 1, 4, 12, 0), 2, 1) # id = 3
|
||||
]:
|
||||
Event.objects.create(start=start, home_team_id=home_team_id, away_team_id=away_team_id)
|
||||
class TestEventViews(TestCase):
|
||||
fixtures = FIXTURES
|
||||
|
||||
for event_id in [
|
||||
1
|
||||
]:
|
||||
for player_id, available in [
|
||||
(1,"Yes"),
|
||||
(2,"No")
|
||||
]:
|
||||
Availability.objects.create(event_id=event_id, player_id=player_id, available=available)
|
||||
def test_event_list(self):
|
||||
response = self.client.get(reverse('schedule'))
|
||||
self.assertEqual(200, response.status_code)
|
||||
|
||||
for event_id in [
|
||||
1
|
||||
]:
|
||||
for player_id, position in [
|
||||
(1, "C"),
|
||||
(2, "1B")
|
||||
]:
|
||||
Positioning.objects.create(event_id=event_id, player_id=player_id, position=position)
|
||||
def test_event_edit(self):
|
||||
response = self.client.get(reverse('edit event', args=[2]))
|
||||
self.assertEqual(200, response.status_code)
|
||||
|
||||
for event_id in [
|
||||
2
|
||||
]:
|
||||
for player_id, available in [
|
||||
(1,"Yes"),
|
||||
(2,"Yes")
|
||||
]:
|
||||
Availability.objects.create(event_id=event_id, player_id=player_id, available=available)
|
||||
|
||||
for event_id in [
|
||||
3
|
||||
]:
|
||||
for player_id, available in [
|
||||
(1,"No"),
|
||||
(2,"No")
|
||||
]:
|
||||
Availability.objects.create(event_id=event_id, player_id=player_id, available=available)
|
||||
pass
|
||||
|
||||
|
||||
def test_player(self):
|
||||
"""Test that player works"""
|
||||
player_1 = Player.objects.get(first_name="Rush")
|
||||
player_2 = Player.objects.get(first_name="Baby")
|
||||
self.assertEqual(str(player_1), f"Valenzuela, Rush")
|
||||
self.assertEqual(str(player_2), f"Triumphant, Baby")
|
||||
pass
|
||||
|
||||
def test_event(self):
|
||||
event = Event.objects.get(pk=1)
|
||||
self.assertEqual(event.start.year, 2020)
|
||||
self.assertEqual(event.start.month, 1)
|
||||
self.assertEqual(event.start.day, 2)
|
||||
self.assertEqual(event.start.hour, 12)
|
||||
self.assertEqual(event.start.minute, 0)
|
||||
self.assertEqual(event.home_team.name, "Firefighters")
|
||||
self.assertEqual(event.away_team.name, "Garages")
|
||||
|
||||
def test_availability(self):
|
||||
availability_1 = Availability.objects.get(event_id=1, player_id=1)
|
||||
availability_2 = Availability.objects.get(event_id=1, player_id=2)
|
||||
|
||||
self.assertEqual(availability_1.available, "Yes")
|
||||
self.assertEqual(availability_2.available, "No")
|
||||
pass
|
||||
|
||||
def test_positioning(self):
|
||||
positioning_1 = Positioning.objects.get(event_id=1, player_id=1)
|
||||
positioning_2 = Positioning.objects.get(event_id=1, player_id=2)
|
||||
# positing_1
|
||||
pass
|
||||
|
||||
def test_combine_info(self):
|
||||
event = Event.objects.get(pk=1)
|
||||
event_id = 1
|
||||
player_query = Player.objects.all()
|
||||
positioning_query = Positioning.objects.filter(event=event).select_related('player')
|
||||
availability_query = Availability.objects.filter(event=event).select_related('player')
|
||||
player_event_info = []
|
||||
|
||||
for player in player_query:
|
||||
player_event_info.append(
|
||||
{
|
||||
"player":player,
|
||||
"positioning":positioning_query.get(player_id=player.id),
|
||||
"availability":availability_query.get(player_id=player.id)
|
||||
# create new event
|
||||
new_event_data = {
|
||||
'home_team': 23,
|
||||
'away_team': 24,
|
||||
'start':datetime(
|
||||
year=2021,
|
||||
month=1,
|
||||
day=1,
|
||||
hour=9,
|
||||
minute=0,
|
||||
second=0),
|
||||
'venue':19
|
||||
}
|
||||
)
|
||||
|
||||
pass
|
||||
response = self.client.post(reverse('edit event', args=[0]), data=new_event_data)
|
||||
self.assertEqual(201, response.status_code)
|
||||
new_event = Event.objects.get(id=response.context['id'])
|
||||
self.assertEqual(new_event_data['home_team'], new_event.home_team.id)
|
||||
self.assertEqual(new_event_data['away_team'], new_event.away_team_id)
|
||||
self.assertEqual(new_event_data['start'], new_event.start)
|
||||
|
||||
# modify event
|
||||
modified_event_data = {
|
||||
'home_team': 23,
|
||||
'away_team': 24,
|
||||
'start':datetime(
|
||||
year=2021,
|
||||
month=1,
|
||||
day=1,
|
||||
hour=9,
|
||||
minute=0,
|
||||
second=0),
|
||||
'venue':19
|
||||
}
|
||||
response = self.client.post(reverse('edit event', args=[1]), data=modified_event_data)
|
||||
self.assertEqual(200, response.status_code)
|
||||
self.assertEqual(1, response.context['id'])
|
||||
modified_event = Event.objects.get(id=response.context['id'])
|
||||
|
||||
self.assertEqual(modified_event_data['home_team'], modified_event.home_team.id)
|
||||
self.assertEqual(modified_event_data['away_team'], modified_event.away_team.id)
|
||||
self.assertEqual(modified_event_data['start'], modified_event.start)
|
||||
self.assertEqual(modified_event_data['venue'], modified_event.venue.id)
|
||||
|
||||
@@ -1,4 +1,6 @@
|
||||
from django.shortcuts import render, redirect, get_object_or_404
|
||||
from django.http import HttpResponse
|
||||
from django.urls import reverse
|
||||
from .models import Event
|
||||
from .forms import EventForm
|
||||
from django.http import HttpResponse
|
||||
@@ -24,8 +26,11 @@ def edit(request, id=0):
|
||||
# process the data in form.cleaned_data as required
|
||||
# ...
|
||||
# redirect to a new URL:
|
||||
if id == 0: id = None
|
||||
new_event, did_create = Event.objects.update_or_create(pk=id, defaults=form.cleaned_data)
|
||||
return render(request, 'success.html', {'call_back':'schedule'})
|
||||
return render(request, 'success.html', {'call_back':reverse('schedule'),'id':new_event.id}, status=201 if did_create else 200)
|
||||
else:
|
||||
return HttpResponse(status=400)
|
||||
|
||||
# if a GET (or any other method) we'll create a blank form
|
||||
else:
|
||||
|
||||
@@ -9,7 +9,7 @@
|
||||
<div class="row">
|
||||
<div class="col-6">
|
||||
{# <ul class="list-group">#}
|
||||
<form action="{% url 'edit lineup' id=event.id%}" method="post">
|
||||
<form action="{% url 'edit lineup' event_id=event.id%}" method="post">
|
||||
|
||||
{# {% csrf_token %}#}
|
||||
{# {{ positionings_formset.management_form }}#}
|
||||
|
||||
@@ -1,3 +1,52 @@
|
||||
from django.test import TestCase
|
||||
from django.test import TestCase, Client
|
||||
from django.test.utils import setup_test_environment
|
||||
from django.urls import reverse
|
||||
from .models import Positioning, Player
|
||||
from .forms import PositioningFormSet
|
||||
|
||||
# Create your tests here.
|
||||
class TestVenueViews(TestCase):
|
||||
fixtures = ['blaseball']
|
||||
|
||||
def test_positioning_list(self):
|
||||
response = self.client.get(reverse('edit lineup', args=[1]))
|
||||
self.assertEqual(response.status_code, 200)
|
||||
|
||||
def test_positioning_formset(self):
|
||||
event = 1
|
||||
|
||||
sample_data = [
|
||||
# first player positioning
|
||||
(1, Player.objects.get(id=1).id, 'P'),
|
||||
(2, Player.objects.get(id=2).id, 'C'),
|
||||
(3, Player.objects.get(id=3).id, '1B')
|
||||
]
|
||||
data = {}
|
||||
|
||||
for i, (order, player, position) in enumerate(sample_data):
|
||||
data[f'form-{i}-order']=order
|
||||
data[f'form-{i}-player']=player
|
||||
data[f'form-{i}-position'] = position
|
||||
|
||||
management = {
|
||||
'form-INITIAL_FORMS': '0',
|
||||
'form-TOTAL_FORMS': len(sample_data),
|
||||
'form-MAX_NUM_FORMS': ''
|
||||
}
|
||||
|
||||
formset = PositioningFormSet({**management, **data})
|
||||
|
||||
self.assertTrue(formset.is_valid())
|
||||
for form in formset:
|
||||
self.assertTrue(form.is_valid())
|
||||
|
||||
response = self.client.post(reverse('edit lineup', args=[event]), {**management, **data})
|
||||
|
||||
self.assertEqual(response.status_code, 200)
|
||||
|
||||
for d in sample_data:
|
||||
with self.subTest(d):
|
||||
p = Positioning.objects.get(player_id=d[1], event_id=event)
|
||||
self.assertEqual(d[0], p.order)
|
||||
self.assertEqual(d[2], p.position)
|
||||
pass
|
||||
@@ -5,5 +5,5 @@ from django.urls import path, include
|
||||
from . import views
|
||||
|
||||
urlpatterns = [
|
||||
path('edit/<int:id>', views.edit, name="edit lineup"),
|
||||
path('edit/<int:event_id>', views.edit, name="edit lineup"),
|
||||
]
|
||||
@@ -8,7 +8,7 @@ from events.models import Event
|
||||
from players.models import Player
|
||||
|
||||
# Create your views here.
|
||||
def edit(request, id):
|
||||
def edit(request, event_id):
|
||||
|
||||
if request.method == 'POST':
|
||||
# create a form instance and populate it with data from the request:
|
||||
@@ -18,12 +18,21 @@ def edit(request, id):
|
||||
# process the data in form.cleaned_data as required
|
||||
# ...
|
||||
# redirect to a new URL:
|
||||
form.cleaned_data.pop('id') #FIXME this is a workaround, not sure why it is necessary
|
||||
new_positioning, did_create = Positioning.objects.update_or_create(id=form['id'].data, defaults=form.cleaned_data)
|
||||
# form.cleaned_data.pop('id')
|
||||
|
||||
if isinstance(form.cleaned_data['id'], Positioning):
|
||||
positioning_id = form.cleaned_data.pop('id').id #FIXME this is a workaround, not sure why it is necessary
|
||||
positioning = Positioning.objects.filter(id=positioning_id)
|
||||
positioning.update(**form.cleaned_data)
|
||||
did_create = False
|
||||
else:
|
||||
positioning = Positioning.objects.create(**form.cleaned_data, event_id=event_id)
|
||||
did_create = True
|
||||
return render(request, 'success.html', {'call_back':'edit lineup','id':event_id}, status=200)
|
||||
# return render(request, 'success.html', {'call_back':'schedule'})
|
||||
event = Event.objects.get(id=id)
|
||||
event = Event.objects.get(id=event_id)
|
||||
players = Player.objects.all()
|
||||
qset = Positioning.objects.filter(event_id=id, order__isnull = False)
|
||||
qset = Positioning.objects.filter(event_id=event_id, order__isnull = False)
|
||||
formset = PositioningFormSet(queryset=qset)
|
||||
for form in formset:
|
||||
for field in form.fields:
|
||||
|
||||
@@ -1,3 +1,58 @@
|
||||
from django.test import TestCase
|
||||
from django.test import TestCase, Client
|
||||
from django.urls import reverse
|
||||
from .models import Player
|
||||
|
||||
FIXTURES = ['blaseball']
|
||||
|
||||
class TestPlayerModel(TestCase):
|
||||
fixtures = FIXTURES
|
||||
|
||||
def test_query_player(self):
|
||||
"""
|
||||
Return the desired player
|
||||
"""
|
||||
player = Player.objects.get(id=1)
|
||||
self.assertEqual(player.first_name, "Edric")
|
||||
self.assertEqual(player.last_name, "Tosser")
|
||||
self.assertEqual(player.jersey_number, 1)
|
||||
self.assertEqual(player.team.name, "Chicago Firefighters")
|
||||
|
||||
class TestPlayerViews(TestCase):
|
||||
fixtures = FIXTURES
|
||||
|
||||
def test_player_list(self):
|
||||
response = self.client.get(reverse('players list'))
|
||||
self.assertEqual(response.status_code, 200)
|
||||
|
||||
def test_player_edit(self):
|
||||
response = self.client.get(reverse('edit player', args=[1]))
|
||||
self.assertEqual(response.status_code, 200)
|
||||
|
||||
# create new player
|
||||
new_player_data = {
|
||||
'first_name': "A new player first name",
|
||||
'last_name': "A new player last name",
|
||||
'jersey_number':99,
|
||||
'team':1
|
||||
}
|
||||
|
||||
response = self.client.post(reverse('edit player', args=[0]), data=new_player_data)
|
||||
self.assertEqual(201, response.status_code)
|
||||
new_player = Player.objects.get(id=response.context['id'])
|
||||
self.assertEqual(new_player_data['first_name'], new_player.first_name)
|
||||
self.assertEqual(new_player_data['last_name'], new_player.last_name)
|
||||
|
||||
# modify player
|
||||
modified_player_data = {
|
||||
'first_name': "A changed player first name",
|
||||
'last_name': "A changed player last name",
|
||||
'jersey_number': 99,
|
||||
'team': 1
|
||||
}
|
||||
response = self.client.post(reverse('edit player', args=[1]), data=modified_player_data)
|
||||
self.assertEqual(200, response.status_code)
|
||||
self.assertEqual(1, response.context['id'])
|
||||
modified_player = Player.objects.get(id=response.context['id'])
|
||||
self.assertEqual(modified_player_data['first_name'], modified_player.first_name)
|
||||
self.assertEqual(modified_player_data['last_name'], modified_player.last_name)
|
||||
|
||||
# Create your tests here.
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
from django.shortcuts import render, redirect, get_object_or_404
|
||||
from django.http import HttpResponse
|
||||
from django.urls import reverse
|
||||
from .models import Player
|
||||
from .forms import PlayerForm
|
||||
|
||||
@@ -30,10 +31,11 @@ def edit(request, id=0):
|
||||
# check whether it's valid:
|
||||
if form.is_valid():
|
||||
# process the data in form.cleaned_data as required
|
||||
# ...
|
||||
# redirect to a new URL:
|
||||
if id == 0: id = None
|
||||
new_player, did_create = Player.objects.update_or_create(pk=id, defaults=form.cleaned_data)
|
||||
return render(request, 'success.html', {'call_back':'players list'})
|
||||
return render(request, 'success.html', {'call_back':reverse('players list'),'id':new_player.id}, status=201 if did_create else 200)
|
||||
else:
|
||||
return HttpResponse(status=400)
|
||||
|
||||
# if a GET (or any other method) we'll create a blank form
|
||||
else:
|
||||
|
||||
@@ -1,3 +1,41 @@
|
||||
from django.urls import reverse
|
||||
from django.test import TestCase
|
||||
from .models import Team
|
||||
|
||||
# Create your tests here.
|
||||
class TestTeamModel(TestCase):
|
||||
fixtures = ['blaseball']
|
||||
|
||||
def test_query_team(self):
|
||||
"""
|
||||
Return the desired team
|
||||
"""
|
||||
team = Team.objects.get(id=1)
|
||||
self.assertEqual(team.name, "Chicago Firefighters")
|
||||
|
||||
class TestTeamViews(TestCase):
|
||||
fixtures = ['blaseball']
|
||||
|
||||
def test_team_list(self):
|
||||
response = self.client.get(reverse('teams list'))
|
||||
self.assertEqual(response.status_code, 200)
|
||||
self.assertIn({'id':1, 'title':'Chicago Firefighters'}, response.context['items'])
|
||||
self.assertIn({'id':2, 'title':'Boston Flowers'}, response.context['items'])
|
||||
self.assertIn({'id':24, 'title':'Baltimore Crabs'}, response.context['items'])
|
||||
|
||||
def test_team_edit(self):
|
||||
response = self.client.get(reverse('edit team', args=[1]))
|
||||
self.assertEqual(response.status_code, 200)
|
||||
|
||||
#create new team
|
||||
response = self.client.post(reverse('edit team', args=[0]), data={'name': "A new team"})
|
||||
self.assertEqual(201, response.status_code)
|
||||
new_team = Team.objects.get(id=response.context['id'])
|
||||
self.assertEqual('A new team',new_team.name, )
|
||||
|
||||
# modify team
|
||||
response = self.client.post(reverse('edit team', args=[1]), data={'name': "A different team name"})
|
||||
self.assertEqual(200, response.status_code)
|
||||
self.assertEqual(1, response.context['id'])
|
||||
modified_team = Team.objects.get(id=response.context['id'])
|
||||
self.assertEqual('A different team name', modified_team.name)
|
||||
@@ -1,5 +1,6 @@
|
||||
from django.shortcuts import render, redirect, get_object_or_404
|
||||
from django.http import HttpResponse
|
||||
from django.urls import reverse
|
||||
from .forms import TeamForm
|
||||
from .models import Team
|
||||
|
||||
@@ -31,7 +32,7 @@ def edit(request, id=0):
|
||||
# ...
|
||||
# redirect to a new URL:
|
||||
new_team, did_create = Team.objects.update_or_create(pk=id, defaults=form.cleaned_data)
|
||||
return render(request, 'success.html', {'call_back':'teams list'})
|
||||
return render(request, 'success.html', {'call_back_url':reverse('teams list'), 'id':new_team.id},status=201 if did_create else 200)
|
||||
|
||||
# if a GET (or any other method) we'll create a blank form
|
||||
else:
|
||||
|
||||
@@ -3,10 +3,12 @@
|
||||
|
||||
{% block content %}
|
||||
|
||||
<head>
|
||||
<meta http-equiv="refresh" content="2;url={% url call_back %}" />
|
||||
</head>
|
||||
<head>
|
||||
|
||||
<span class="text-success">Success!</span> <span class="text-muted">Redirecting...</span>
|
||||
<meta http-equiv="refresh" content="2;url={{ call_back_url }}" />
|
||||
|
||||
</head>
|
||||
|
||||
<span class="text-success">Success!</span> <span class="text-muted">Redirecting...</span>
|
||||
|
||||
{% endblock %}
|
||||
@@ -1,3 +1,40 @@
|
||||
from django.test import TestCase
|
||||
from django.urls import reverse
|
||||
from .models import Venue
|
||||
|
||||
# Create your tests here.
|
||||
class TestVenueModel(TestCase):
|
||||
fixtures = ['blaseball']
|
||||
|
||||
def test_query_venue(self):
|
||||
"""
|
||||
Return the desired venue
|
||||
"""
|
||||
venue = Venue.objects.get(id=1)
|
||||
self.assertEqual(venue.name, "Chesapeake Racetrack and Ballpark")
|
||||
|
||||
class TestVenueViews(TestCase):
|
||||
fixtures = ['blaseball']
|
||||
|
||||
def test_venue_list(self):
|
||||
response = self.client.get(reverse('venues list'))
|
||||
self.assertEqual(response.status_code, 200)
|
||||
self.assertIn({'id':1, 'title':'Chesapeake Racetrack and Ballpark'}, response.context['items'])
|
||||
self.assertIn({'id':2, 'title':'Tokyo Fitness Center'}, response.context['items'])
|
||||
self.assertIn({'id':25, 'title':'ILB Historical Preservation Site'}, response.context['items'])
|
||||
|
||||
def test_venue_edit(self):
|
||||
response = self.client.get(reverse('edit venue', args=[1]))
|
||||
self.assertEqual(response.status_code, 200)
|
||||
|
||||
#create new venue
|
||||
response = self.client.post(reverse('edit venue', args=[0]), data={'name': "A new venue"})
|
||||
self.assertEqual(201, response.status_code)
|
||||
new_venue = Venue.objects.get(id=response.context['id'])
|
||||
self.assertEqual('A new venue',new_venue.name, )
|
||||
|
||||
# modify venue
|
||||
response = self.client.post(reverse('edit venue', args=[1]), data={'name': "A different venue name"})
|
||||
self.assertEqual(200, response.status_code)
|
||||
self.assertEqual(1, response.context['id'])
|
||||
modified_venue = Venue.objects.get(id=response.context['id'])
|
||||
self.assertEqual('A different venue name', modified_venue.name)
|
||||
@@ -1,5 +1,6 @@
|
||||
from django.shortcuts import render, redirect, get_object_or_404
|
||||
from django.http import HttpResponse, HttpResponseBadRequest
|
||||
from django.urls import reverse
|
||||
from .models import Venue
|
||||
from .forms import VenueForm
|
||||
|
||||
@@ -32,7 +33,7 @@ def edit(request, id=0):
|
||||
# ...
|
||||
# redirect to a new URL:
|
||||
new_venue, did_create = Venue.objects.update_or_create(pk=id, defaults=form.cleaned_data)
|
||||
return render(request, 'success.html', {'call_back':'players list','id':new_venue.id}, status=201 if did_create else 200)
|
||||
return render(request, 'success.html', {'call_back_url':reverse('venues list'), 'id':new_venue.id}, status=201 if did_create else 200)
|
||||
return HttpResponseBadRequest()
|
||||
|
||||
# if a GET (or any other method) we'll create a blank form
|
||||
|
||||
Reference in New Issue
Block a user