From b374ecda39028efc55f291df7b9b17c61e509bc7 Mon Sep 17 00:00:00 2001 From: Andy Baker Date: Sat, 6 Jun 2015 16:34:32 +0100 Subject: [PATCH 1/2] support South migrations for backwards compatibility --- linkcheck/south_migrations/0001_initial.py | 72 ++++++++++++++++++++++ linkcheck/south_migrations/__init__.py | 0 2 files changed, 72 insertions(+) create mode 100644 linkcheck/south_migrations/0001_initial.py create mode 100644 linkcheck/south_migrations/__init__.py diff --git a/linkcheck/south_migrations/0001_initial.py b/linkcheck/south_migrations/0001_initial.py new file mode 100644 index 0000000..2583506 --- /dev/null +++ b/linkcheck/south_migrations/0001_initial.py @@ -0,0 +1,72 @@ +# -*- coding: utf-8 -*- +from south.utils import datetime_utils as datetime +from south.db import db +from south.v2 import SchemaMigration +from django.db import models + + +class Migration(SchemaMigration): + + def forwards(self, orm): + # Adding model 'Url' + db.create_table(u'linkcheck_url', ( + (u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), + ('url', self.gf('django.db.models.fields.CharField')(unique=True, max_length=255)), + ('last_checked', self.gf('django.db.models.fields.DateTimeField')(null=True, blank=True)), + ('status', self.gf('django.db.models.fields.NullBooleanField')(null=True, blank=True)), + ('message', self.gf('django.db.models.fields.CharField')(max_length=1024, null=True, blank=True)), + ('still_exists', self.gf('django.db.models.fields.BooleanField')(default=False)), + )) + db.send_create_signal(u'linkcheck', ['Url']) + + # Adding model 'Link' + db.create_table(u'linkcheck_link', ( + (u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), + ('content_type', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['contenttypes.ContentType'])), + ('object_id', self.gf('django.db.models.fields.PositiveIntegerField')()), + ('field', self.gf('django.db.models.fields.CharField')(max_length=128)), + ('url', self.gf('django.db.models.fields.related.ForeignKey')(related_name=u'links', to=orm['linkcheck.Url'])), + ('text', self.gf('django.db.models.fields.CharField')(default=u'', max_length=256)), + ('ignore', self.gf('django.db.models.fields.BooleanField')(default=False)), + )) + db.send_create_signal(u'linkcheck', ['Link']) + + + def backwards(self, orm): + # Deleting model 'Url' + db.delete_table(u'linkcheck_url') + + # Deleting model 'Link' + db.delete_table(u'linkcheck_link') + + + models = { + u'contenttypes.contenttype': { + 'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"}, + 'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}), + u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), + 'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}), + 'name': ('django.db.models.fields.CharField', [], {'max_length': '100'}) + }, + u'linkcheck.link': { + 'Meta': {'object_name': 'Link'}, + 'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['contenttypes.ContentType']"}), + 'field': ('django.db.models.fields.CharField', [], {'max_length': '128'}), + u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), + 'ignore': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), + 'object_id': ('django.db.models.fields.PositiveIntegerField', [], {}), + 'text': ('django.db.models.fields.CharField', [], {'default': "u''", 'max_length': '256'}), + 'url': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "u'links'", 'to': u"orm['linkcheck.Url']"}) + }, + u'linkcheck.url': { + 'Meta': {'object_name': 'Url'}, + u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), + 'last_checked': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), + 'message': ('django.db.models.fields.CharField', [], {'max_length': '1024', 'null': 'True', 'blank': 'True'}), + 'status': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}), + 'still_exists': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), + 'url': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}) + } + } + + complete_apps = ['linkcheck'] \ No newline at end of file diff --git a/linkcheck/south_migrations/__init__.py b/linkcheck/south_migrations/__init__.py new file mode 100644 index 0000000..e69de29 From e8e65bbf89307ec73fbc0b877e1b892e85e8a236 Mon Sep 17 00:00:00 2001 From: Chen Zhe Date: Mon, 8 Aug 2016 18:25:48 +0800 Subject: [PATCH 2/2] follow redirect for internal checks --- linkcheck/models.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/linkcheck/models.py b/linkcheck/models.py index 1f1cba6..e737555 100644 --- a/linkcheck/models.py +++ b/linkcheck/models.py @@ -240,7 +240,7 @@ def _check_internal(self, tested_url): settings.PREPEND_WWW = False c = Client() c.handler = LinkCheckHandler() - response = c.get(tested_url) + response = c.get(tested_url, follow=True) if USE_REVERSION: # using test client will clear the RevisionContextManager stack. revision_context_manager.start()