def setUp(self): self.u1 = User(username='******') self.u2 = User(username='******') self.u1.save() self.u2.save() self.article1 = Article(slug=u'TDT4100') self.article1.save() self.article2 = Article(slug=u'TIØ4258') self.article2.save() self.ac1 = ArticleContent(article=self.article1, updated=datetime.datetime(2012, 1, 1)) self.ac2 = ArticleContent(article=self.article1, updated=datetime.datetime(2013, 1, 1), title='per') self.ac3 = ArticleContent(article=self.article2, updated=datetime.datetime(2001, 3, 7)) self.ac4 = ArticleContent(article=self.article2, updated=datetime.datetime(2001, 3, 8), lang='nb') self.ac1.edited_by = self.u1 self.ac2.edited_by = self.u2 self.ac3.edited_by = self.u1 self.ac4.edited_by = self.u2 self.ac1.save() self.ac2.save() self.ac3.save() self.ac4.save()
def new(request, slug=None): if request.POST: form = NewArticleForm(request.POST) if form.is_valid(): slug = request.POST.get('slug') article = Article(slug=slug) article.save() article_content = form.save(commit=False) article_content.article = article article_content.edited_by = request.user article_content.save() return HttpResponseRedirect(article_content.get_absolute_url()) else: article_content = None if slug: slug = slug.upper() article_content = ArticleContent(article=Article(slug=slug), lang=None) form = NewArticleForm(instance=article_content) return render(request, 'edit.html', { 'mathjax': True, 'form': form, 'title': 'Create compendium', })
def test_slug_cannot_contain_slashes(self): article = Article() article.slug = u'TDT/4100' try: article.save() self.assertEqual(1, 2) # this should not be reached except ValidationError: self.assertEqual(1, 1) # correct error was raised
def setUp(self): self.article1 = Article(slug=u'TDT4100') self.article1.save() self.ac1 = ArticleContent(article=self.article1, updated=datetime.datetime(2012, 1, 1), title='Cooking and baking', lang='fr', content='# Title') self.ac2 = ArticleContent(article=self.article1, updated=datetime.datetime(2014, 1, 1), title='Cooking and baking', lang='fr') self.ac1.save() self.ac2.save()
def merge_contents_if_needed(self): parent_id = self.cleaned_data['parent_id'] article = None articleContent = None slug = self.cleaned_data['slug'] lang = self.cleaned_data['lang'] try: article = Article.objects.get(slug=slug) except: article = Article(slug=slug) articleContent = article.get_newest_content(lang) if articleContent is None: articleContent = ArticleContent(article=article, lang=lang) if parent_id and parent_id != articleContent.pk: parent = ArticleContent.objects.get(id=parent_id) a = parent b = articleContent ancestors = set() commonAncestor = None while True: if a and a.pk in ancestors: commonAncestor = a break if b and b.pk in ancestors: commonAncestor = b break ancestors.add(a.pk) ancestors.add(b.pk) a = a.parent b = b.parent if a and a.parent is None and b and b.parent is None: break try: merged = merge(self.cleaned_data['content'], commonAncestor.content, articleContent.content) self.cleaned_data['content'] = merged except MergeError as e: raise ValidationError('Merge conflict.', params={'diff': e.diff}) return True
def new(request): if request.POST: form = NewArticleForm(request.POST) if form.is_valid(): slug = request.POST.get('slug') article = Article(slug=slug) article.save() articleContent = form.save(commit=False) articleContent.article = article articleContent.edited_by = request.user articleContent.save() return HttpResponseRedirect(articleContent.get_absolute_url()) else: form = NewArticleForm() return render(request, 'edit.html', { "mathjax": True, "form": form, "title": "Create article", })
def test_slug_should_strip_whitespace_when_saved(self): article = Article() article.slug = u' PADDED\v\t \n' article.save() self.assertEqual(article.slug, u'PADDED')
def test_slug_should_uppercase_when_saved(self): article = Article() article.slug = u'lowercase' article.save() self.assertEqual(article.slug, u'LOWERCASE')
def test_slug_should_uppercase_when_saved(self): article = Article() article.slug = "lowercase" article.save() self.assertEqual(article.slug, "LOWERCASE")