Show More
@@ -41,10 +41,13 b' class PostManager(models.Manager):' | |||
|
41 | 41 | return threads |
|
42 | 42 | |
|
43 | 43 | def get_thread(self, opening_post_id): |
|
44 | opening_post = self.get(opening_post_id) | |
|
45 |
replies = |
|
|
44 | opening_post = self.get(id = opening_post_id) | |
|
45 | replies = self.filter(parent = opening_post_id) | |
|
46 | 46 | |
|
47 |
|
|
|
47 | thread = [opening_post] | |
|
48 | thread.extend(replies) | |
|
49 | ||
|
50 | return thread | |
|
48 | 51 | |
|
49 | 52 | def exists(self, post_id): |
|
50 | 53 | posts = self.filter(id = post_id) |
@@ -86,3 +86,14 b' class BoardTests(TestCase):' | |||
|
86 | 86 | |
|
87 | 87 | admin.delete() |
|
88 | 88 | |
|
89 | def test_get_thread(self): | |
|
90 | opening_post = self._create_post() | |
|
91 | op_id = opening_post.id | |
|
92 | ||
|
93 | for i in range(0, 2): | |
|
94 | Post.objects.create_post('title', 'text', | |
|
95 | parent_id = op_id) | |
|
96 | ||
|
97 | thread = Post.objects.get_thread(op_id) | |
|
98 | ||
|
99 | self.assertEqual(3, thread.__len__()) |
@@ -12,9 +12,9 b" urlpatterns = patterns(''," | |||
|
12 | 12 | url(r'^logout$', views.logout, name='logout'), |
|
13 | 13 | |
|
14 | 14 | # /boards/tag/ |
|
15 | url(r'^(?P<tag>\w+)/$', views.tag, name = 'tag'), | |
|
15 | url(r'^tag/(?P<tag>\w+)/$', views.tag, name = 'tag'), | |
|
16 | 16 | # /boards/post_id/ |
|
17 |
url(r'^ |
|
|
17 | url(r'^post/(?P<id>\w+)/$', views.thread, name = 'thread'), | |
|
18 | 18 | # /boards/tag/post/ |
|
19 | 19 | url(r'^post.html$', views.new_post, |
|
20 | 20 | name='post'), |
@@ -47,18 +47,17 b' def tag(request):' | |||
|
47 | 47 | return render(request, 'posting_general.html', |
|
48 | 48 | context) |
|
49 | 49 | |
|
50 | def thread(request): | |
|
50 | def thread(request, id): | |
|
51 | 51 | """Get all thread posts""" |
|
52 | 52 | |
|
53 | 53 | # TODO Show 404 if there is no such thread |
|
54 | 54 | |
|
55 | opening_post_id = request.GET['id'] | |
|
56 | posts = Post.objects.get_thread(opening_post_id) | |
|
55 | posts = Post.objects.get_thread(id) | |
|
57 | 56 | |
|
58 | 57 | context = RequestContext(request) |
|
59 | 58 | context['posts'] = posts |
|
60 | 59 | |
|
61 |
return render(request |
|
|
60 | return render(request, 'thread.html', context) | |
|
62 | 61 | |
|
63 | 62 | def login(request): |
|
64 | 63 | """Log in as admin""" |
@@ -6,7 +6,8 b'' | |||
|
6 | 6 | {% for thread in threads %} |
|
7 | 7 | <span class="title">{{ thread.title }}</span><br /> |
|
8 | 8 | <span class="text">{{ thread.text }}</span><br /> |
|
9 |
<a class="link" href="/boards/ |
|
|
9 | <a class="link" href="/boards/post/{{ thread.id }}/">View | |
|
10 | thread</a> | |
|
10 | 11 | <hr /> |
|
11 | 12 | {% endfor %} |
|
12 | 13 | {% else %} |
General Comments 0
You need to be logged in to leave comments.
Login now