Make django_orm models use TEXT instead of VARCHAR.
Reviewed in http://codereview.appspot.com/5165047/
This commit is contained in:
@@ -31,8 +31,8 @@ class CredentialsField(models.Field):
|
|||||||
|
|
||||||
__metaclass__ = models.SubfieldBase
|
__metaclass__ = models.SubfieldBase
|
||||||
|
|
||||||
def db_type(self, connection=None):
|
def get_internal_type(self):
|
||||||
return 'VARCHAR'
|
return "TextField"
|
||||||
|
|
||||||
def to_python(self, value):
|
def to_python(self, value):
|
||||||
if not value:
|
if not value:
|
||||||
@@ -41,7 +41,7 @@ class CredentialsField(models.Field):
|
|||||||
return value
|
return value
|
||||||
return pickle.loads(base64.b64decode(value))
|
return pickle.loads(base64.b64decode(value))
|
||||||
|
|
||||||
def get_db_prep_value(self, value):
|
def get_db_prep_value(self, value, connection, prepared=False):
|
||||||
return base64.b64encode(pickle.dumps(value))
|
return base64.b64encode(pickle.dumps(value))
|
||||||
|
|
||||||
|
|
||||||
@@ -49,8 +49,8 @@ class FlowField(models.Field):
|
|||||||
|
|
||||||
__metaclass__ = models.SubfieldBase
|
__metaclass__ = models.SubfieldBase
|
||||||
|
|
||||||
def db_type(self, connection=None):
|
def get_internal_type(self):
|
||||||
return 'VARCHAR'
|
return "TextField"
|
||||||
|
|
||||||
def to_python(self, value):
|
def to_python(self, value):
|
||||||
if value is None:
|
if value is None:
|
||||||
@@ -59,7 +59,7 @@ class FlowField(models.Field):
|
|||||||
return value
|
return value
|
||||||
return pickle.loads(base64.b64decode(value))
|
return pickle.loads(base64.b64decode(value))
|
||||||
|
|
||||||
def get_db_prep_value(self, value):
|
def get_db_prep_value(self, value, connection, prepared=False):
|
||||||
return base64.b64encode(pickle.dumps(value))
|
return base64.b64encode(pickle.dumps(value))
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -19,6 +19,10 @@ except:
|
|||||||
sys.path.insert(0, os.getcwd())
|
sys.path.insert(0, os.getcwd())
|
||||||
sys.path.insert(0, APP_ENGINE_PATH)
|
sys.path.insert(0, APP_ENGINE_PATH)
|
||||||
|
|
||||||
|
from google.appengine.dist import use_library
|
||||||
|
use_library('django', '1.2')
|
||||||
|
|
||||||
|
|
||||||
def build_suite(folder, verbosity):
|
def build_suite(folder, verbosity):
|
||||||
# find all of the test modules
|
# find all of the test modules
|
||||||
top_level_modules = map(fullmodname, glob.glob(os.path.join(folder, 'test_*.py')))
|
top_level_modules = map(fullmodname, glob.glob(os.path.join(folder, 'test_*.py')))
|
||||||
|
|||||||
75
tests/test_oauth2client_django_orm.py
Normal file
75
tests/test_oauth2client_django_orm.py
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
#!/usr/bin/python2.4
|
||||||
|
#
|
||||||
|
# Copyright 2011 Google Inc.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
|
||||||
|
"""Discovery document tests
|
||||||
|
|
||||||
|
Unit tests for objects created from discovery documents.
|
||||||
|
"""
|
||||||
|
|
||||||
|
__author__ = 'conleyo@google.com (Conley Owens)'
|
||||||
|
|
||||||
|
import base64
|
||||||
|
import imp
|
||||||
|
import os
|
||||||
|
import pickle
|
||||||
|
import sys
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
from oauth2client.client import Credentials
|
||||||
|
from oauth2client.client import Flow
|
||||||
|
|
||||||
|
# Mock a Django environment
|
||||||
|
os.environ['DJANGO_SETTINGS_MODULE'] = 'django_settings'
|
||||||
|
sys.modules['django_settings'] = imp.new_module('django_settings')
|
||||||
|
|
||||||
|
from oauth2client.django_orm import CredentialsField
|
||||||
|
from oauth2client.django_orm import FlowField
|
||||||
|
|
||||||
|
|
||||||
|
class TestCredentialsField(unittest.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
self.field = CredentialsField()
|
||||||
|
self.credentials = Credentials()
|
||||||
|
self.pickle = base64.b64encode(pickle.dumps(self.credentials))
|
||||||
|
|
||||||
|
def test_field_is_text(self):
|
||||||
|
self.assertEquals(self.field.get_internal_type(), 'TextField')
|
||||||
|
|
||||||
|
def test_field_unpickled(self):
|
||||||
|
self.assertTrue(isinstance(self.field.to_python(self.pickle), Credentials))
|
||||||
|
|
||||||
|
def test_field_pickled(self):
|
||||||
|
prep_value = self.field.get_db_prep_value(self.credentials,
|
||||||
|
connection=None)
|
||||||
|
self.assertEqual(prep_value, self.pickle)
|
||||||
|
|
||||||
|
|
||||||
|
class TestFlowField(unittest.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
self.field = FlowField()
|
||||||
|
self.flow = Flow()
|
||||||
|
self.pickle = base64.b64encode(pickle.dumps(self.flow))
|
||||||
|
|
||||||
|
def test_field_is_text(self):
|
||||||
|
self.assertEquals(self.field.get_internal_type(), 'TextField')
|
||||||
|
|
||||||
|
def test_field_unpickled(self):
|
||||||
|
self.assertTrue(isinstance(self.field.to_python(self.pickle), Flow))
|
||||||
|
|
||||||
|
def test_field_pickled(self):
|
||||||
|
prep_value = self.field.get_db_prep_value(self.flow, connection=None)
|
||||||
|
self.assertEqual(prep_value, self.pickle)
|
||||||
Reference in New Issue
Block a user