From 8175face4f37c8119c5674958135e2e51a177c24 Mon Sep 17 00:00:00 2001 From: Mike Bayer Date: Tue, 24 Jan 2012 18:10:34 -0500 Subject: [PATCH] - tried it out in my work project, and realized the "op" and "context" namespaces need to be there fully and in particular "context" needs to be a proxy object, as env.py may have dependencies which live beyond the scope of the migration script. Will have to try to make these proxies as straightforward as possible. - more architecture docs --- alembic/__init__.py | 11 +- alembic/environment.py | 4 +- alembic/op.py | 19 ++++ alembic/operations.py | 146 +++++++++++++------------ docs/build/api_overview.png | Bin 62197 -> 64697 bytes docs/build/assets/api_overview.graffle | 98 +++++++++++++++-- docs/build/front.rst | 31 ++++-- docs/build/ops.rst | 3 + 8 files changed, 217 insertions(+), 95 deletions(-) create mode 100644 alembic/op.py diff --git a/alembic/__init__.py b/alembic/__init__.py index e561d0d9..09d91dfa 100644 --- a/alembic/__init__.py +++ b/alembic/__init__.py @@ -5,8 +5,11 @@ __version__ = '0.2.0' package_dir = path.abspath(path.dirname(__file__)) -class _OpProxy(object): - _proxy = None +from alembic import op + +class _ContextProxy(object): + """A proxy object for the current :class:`.EnvironmentContext`.""" def __getattr__(self, key): - return getattr(self._proxy, key) -op = _OpProxy() + return getattr(_context, key) +context = _ContextProxy() + diff --git a/alembic/environment.py b/alembic/environment.py index d562add6..f61c9c7b 100644 --- a/alembic/environment.py +++ b/alembic/environment.py @@ -46,11 +46,11 @@ class EnvironmentContext(object): be made available as ``from alembic import context``. """ - alembic.context = self + alembic._context = self return self def __exit__(self, *arg, **kw): - del alembic.context + alembic._context = None alembic.op._proxy = None def is_offline_mode(self): diff --git a/alembic/op.py b/alembic/op.py new file mode 100644 index 00000000..8a5e0fa0 --- /dev/null +++ b/alembic/op.py @@ -0,0 +1,19 @@ +from alembic.operations import Operations + +# create proxy functions for +# each method on the Operations class. + +# TODO: this is a quick and dirty version of this. +# Ideally, we'd be duplicating method signatures +# and such, using eval(), etc. + +_proxy = None +def _create_op_proxy(name): + def go(*arg, **kw): + return getattr(_proxy, name)(*arg, **kw) + go.__name__ = name + return go + +for methname in dir(Operations): + if not methname.startswith('_'): + locals()[methname] = _create_op_proxy(methname) \ No newline at end of file diff --git a/alembic/operations.py b/alembic/operations.py index 18b8e692..f3e6708c 100644 --- a/alembic/operations.py +++ b/alembic/operations.py @@ -9,10 +9,10 @@ __all__ = ('Operations',) class Operations(object): """Define high level migration operations. - + Each operation corresponds to some schema migration operation, executed against a particular :class:`.MigrationContext`. - + Normally, the :class:`.MigrationContext` is created within an ``env.py`` script via the :meth:`.EnvironmentContext.configure` method. However, @@ -21,14 +21,14 @@ class Operations(object): class - only :class:`.MigrationContext`, which represents connectivity to a single database, is needed to use the directives. - + """ def __init__(self, migration_context): """Construct a new :class:`.Operations` - + :param migration_context: a :class:`.MigrationContext` instance. - + """ self.migration_context = migration_context self.impl = migration_context.impl @@ -111,13 +111,21 @@ class Operations(object): if cname not in rel_t.c: rel_t.append_column(schema.Column(cname, NULLTYPE)) + def get_context(self): + """Return the :class:`.MigrationsContext` object that's + currently in use. + + """ + + return self.migration_context + def rename_table(self, old_table_name, new_table_name, schema=None): """Emit an ALTER TABLE to rename a table. - + :param old_table_name: old name. :param new_table_name: new name. :param schema: Optional, name of schema to operate within. - + """ self.impl.rename_table( old_table_name, @@ -136,21 +144,21 @@ class Operations(object): ): """Issue an "alter column" instruction using the current migration context. - + Generally, only that aspect of the column which is being changed, i.e. name, type, nullability, default, needs to be specified. Multiple changes can also be specified at once and the backend should "do the right thing", emitting each change either separately or together as the backend allows. - + MySQL has special requirements here, since MySQL cannot ALTER a column without a full specification. When producing MySQL-compatible migration files, it is recommended that the ``existing_type``, ``existing_server_default``, and ``existing_nullable`` parameters be present, if not being altered. - + Type changes which are against the SQLAlchemy "schema" types :class:`~sqlalchemy.types.Boolean` and :class:`~sqlalchemy.types.Enum` may also @@ -159,7 +167,7 @@ class Operations(object): The ``existing_server_default`` argument is used in this case as well to remove a previous constraint. - + :param table_name: string name of the target table. :param column_name: string name of the target column, as it exists before the operation begins. @@ -168,12 +176,12 @@ class Operations(object): :param server_default: Optional; specify a string SQL expression, :func:`~sqlalchemy.sql.expression.text`, or :class:`~sqlalchemy.schema.DefaultClause` to indicate - an alteration to the column's default value. + an alteration to the column's default value. Set to ``None`` to have the default removed. :param name: Optional; specify a string name here to indicate the new name within a column rename operation. :param type_: Optional; a :class:`~sqlalchemy.types.TypeEngine` - type object to specify a change to the column's type. + type object to specify a change to the column's type. For SQLAlchemy types that also indicate a constraint (i.e. :class:`~sqlalchemy.types.Boolean`, :class:`~sqlalchemy.types.Enum`), the constraint is also generated. @@ -220,7 +228,7 @@ class Operations(object): def add_column(self, table_name, column): """Issue an "add column" instruction using the current migration context. - + e.g.:: from alembic import op @@ -228,25 +236,25 @@ class Operations(object): op.add_column('organization', Column('name', String()) - ) + ) The provided :class:`~sqlalchemy.schema.Column` object can also specify a :class:`~sqlalchemy.schema.ForeignKey`, referencing a remote table name. Alembic will automatically generate a stub "referenced" table and emit a second ALTER statement in order to add the constraint separately:: - + from alembic import op from sqlalchemy import Column, INTEGER, ForeignKey op.add_column('organization', Column('account_id', INTEGER, ForeignKey('accounts.id')) - ) - + ) + :param table_name: String name of the parent table. :param column: a :class:`sqlalchemy.schema.Column` object representing the new column. - + """ t = self._table(table_name, column) @@ -260,11 +268,11 @@ class Operations(object): def drop_column(self, table_name, column_name, **kw): """Issue a "drop column" instruction using the current migration context. - + e.g.:: - + drop_column('organization', 'account_id') - + :param table_name: name of table :param column_name: name of column :param mssql_drop_check: Optional boolean. When ``True``, on @@ -277,7 +285,7 @@ class Operations(object): drop the DEFAULT constraint on the column using a SQL-script-compatible block that selects into a @variable from sys.default_constraints, then exec's a separate DROP CONSTRAINT for that default. - + """ self.impl.drop_column( @@ -292,7 +300,7 @@ class Operations(object): current migration context. e.g.:: - + from alembic import op op.create_foreign_key("fk_user_address", "address", "user", ["user_id"], ["id"]) @@ -303,7 +311,7 @@ class Operations(object): Any event listeners associated with this action will be fired off normally. The :class:`~sqlalchemy.schema.AddConstraint` construct is ultimately used to generate the ALTER statement. - + :param name: Name of the foreign key constraint. The name is necessary so that an ALTER statement can be emitted. For setups that use an automated naming scheme such as that described at @@ -319,7 +327,7 @@ class Operations(object): source table. :param remote_cols: a list of string column names in the remote table. - + """ self.impl.add_constraint( @@ -331,7 +339,7 @@ class Operations(object): """Issue a "create unique constraint" instruction using the current migration context. e.g.:: - + from alembic import op op.create_unique_constraint("uq_user_name", "user", ["name"]) @@ -342,7 +350,7 @@ class Operations(object): Any event listeners associated with this action will be fired off normally. The :class:`~sqlalchemy.schema.AddConstraint` construct is ultimately used to generate the ALTER statement. - + :param name: Name of the unique constraint. The name is necessary so that an ALTER statement can be emitted. For setups that use an automated naming scheme such as that described at @@ -358,7 +366,7 @@ class Operations(object): issuing DDL for this constraint. :param initially: optional string. If set, emit INITIALLY when issuing DDL for this constraint. - + """ self.impl.add_constraint( @@ -368,18 +376,18 @@ class Operations(object): def create_check_constraint(self, name, source, condition, **kw): """Issue a "create check constraint" instruction using the current migration context. - + e.g.:: - + from alembic import op from sqlalchemy.sql import column, func - + op.create_check_constraint( "ck_user_name_len", "user", func.len(column('name')) > 5 ) - + CHECK constraints are usually against a SQL expression, so ad-hoc table metadata is usually needed. The function will convert the given arguments into a :class:`sqlalchemy.schema.CheckConstraint` bound @@ -394,13 +402,13 @@ class Operations(object): with the table. :param source: String name of the source table. Currently there is no support for dotted schema names. - :param condition: SQL expression that's the condition of the constraint. + :param condition: SQL expression that's the condition of the constraint. Can be a string or SQLAlchemy expression language structure. :param deferrable: optional bool. If set, emit DEFERRABLE or NOT DEFERRABLE when issuing DDL for this constraint. :param initially: optional string. If set, emit INITIALLY when issuing DDL for this constraint. - + """ self.impl.add_constraint( self._check_constraint(name, source, condition, **kw) @@ -408,11 +416,11 @@ class Operations(object): def create_table(self, name, *columns, **kw): """Issue a "create table" instruction using the current migration context. - + This directive receives an argument list similar to that of the traditional :class:`sqlalchemy.schema.Table` construct, but without the metadata:: - + from sqlalchemy import INTEGER, VARCHAR, NVARCHAR, Column from alembic import op @@ -432,7 +440,7 @@ class Operations(object): type will emit a CREATE TYPE within these events. :param \**kw: Other keyword arguments are passed to the underlying :class:`.Table` object created for the command. - + """ self.impl.create_table( self._table(name, *columns, **kw) @@ -440,12 +448,12 @@ class Operations(object): def drop_table(self, name): """Issue a "drop table" instruction using the current migration context. - - + + e.g.:: - + drop_table("accounts") - + """ self.impl.drop_table( self._table(name) @@ -453,9 +461,9 @@ class Operations(object): def create_index(self, name, tablename, *columns, **kw): """Issue a "create index" instruction using the current migration context. - + e.g.:: - + from alembic import op op.create_index('ik_test', 't1', ['foo', 'bar']) @@ -467,12 +475,12 @@ class Operations(object): def drop_index(self, name): """Issue a "drop index" instruction using the current migration context. - - + + e.g.:: - + drop_index("accounts") - + """ self.impl.drop_index(self._index(name, 'foo', [])) @@ -485,26 +493,26 @@ class Operations(object): def bulk_insert(self, table, rows): """Issue a "bulk insert" operation using the current migration context. - + This provides a means of representing an INSERT of multiple rows which works equally well in the context of executing on a live connection as well as that of generating a SQL script. In the case of a SQL script, the values are rendered inline into the statement. - + e.g.:: - + from datetime import date from sqlalchemy.sql import table, column from sqlalchemy import String, Integer, Date - + # Create an ad-hoc table to use for the insert statement. accounts_table = table('account', column('id', Integer), column('name', String), column('create_date', Date) ) - + bulk_insert(accounts_table, [ {'id':1, 'name':'John Smith', 'create_date':date(2010, 10, 5)}, @@ -518,12 +526,12 @@ class Operations(object): def inline_literal(self, value, type_=None): """Produce an 'inline literal' expression, suitable for using in an INSERT, UPDATE, or DELETE statement. - + When using Alembic in "offline" mode, CRUD operations aren't compatible with SQLAlchemy's default behavior surrounding literal values, which is that they are converted into bound values and passed - separately into the ``execute()`` method of the DBAPI cursor. + separately into the ``execute()`` method of the DBAPI cursor. An offline SQL script needs to have these rendered inline. While it should always be noted that inline literal values are an **enormous** @@ -535,7 +543,7 @@ class Operations(object): See :meth:`.execute` for an example usage of :meth:`.inline_literal`. - + :param value: The value to render. Strings, integers, and simple numerics should be supported. Other types like boolean, dates, etc. may or may not be supported yet by various @@ -551,31 +559,31 @@ class Operations(object): def execute(self, sql): """Execute the given SQL using the current migration context. - + In a SQL script context, the statement is emitted directly to the output stream. There is *no* return result, however, as this function is oriented towards generating a change script that can run in "offline" mode. For full interaction with a connected database, use the "bind" available from the context:: - + from alembic import op connection = op.get_bind() - + Also note that any parameterized statement here *will not work* in offline mode - INSERT, UPDATE and DELETE statements which refer to literal values would need to render inline expressions. For simple use cases, the :meth:`.inline_literal` function can be used for **rudimentary** quoting of string values. For "bulk" inserts, consider using :meth:`.bulk_insert`. - + For example, to emit an UPDATE statement which is equally compatible with both online and offline mode:: - + from sqlalchemy.sql import table, column from sqlalchemy import String from alembic import op - + account = table('account', column('name', String) ) @@ -584,7 +592,7 @@ class Operations(object): where(account.c.name==op.inline_literal('account 1')).\\ values({'name':op.inline_literal('account 2')}) ) - + Note above we also used the SQLAlchemy :func:`sqlalchemy.sql.expression.table` and :func:`sqlalchemy.sql.expression.column` constructs to make a brief, ad-hoc table construct just for our UPDATE statement. A full @@ -593,9 +601,9 @@ class Operations(object): the definition of a table is self-contained within the migration script, rather than imported from a module that may break compatibility with older migrations. - + :param sql: Any legal SQLAlchemy expression, including: - + * a string * a :func:`sqlalchemy.sql.expression.text` construct. * a :func:`sqlalchemy.sql.expression.insert` construct. @@ -604,19 +612,19 @@ class Operations(object): * Pretty much anything that's "executable" as described in :ref:`sqlexpression_toplevel`. - + """ self.migration_context.impl.execute(sql) def get_bind(self): """Return the current 'bind'. - + Under normal circumstances, this is the :class:`sqlalchemy.engine.Connection` currently being used to emit SQL to the database. - + In a SQL script context, this value is ``None``. [TODO: verify this] - + """ return self.migration_context.impl.bind diff --git a/docs/build/api_overview.png b/docs/build/api_overview.png index 1ad799399513c67889df3662fc27be72982a5123..dab204b6e30ebda4613bad87cde302d68a74f539 100644 GIT binary patch delta 59148 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 age?6vv8|!Cvg2}4LR7#!PmM)oEom)r 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 diff --git a/docs/build/assets/api_overview.graffle b/docs/build/assets/api_overview.graffle index b363d526..7c083e51 100644 --- a/docs/build/assets/api_overview.graffle +++ b/docs/build/assets/api_overview.graffle @@ -29,6 +29,88 @@ 5 GraphicsList + + Bounds + {{319.25, 165}, {66, 12}} + Class + ShapedGraphic + FitText + YES + Flow + Resize + ID + 2054 + Shape + Rectangle + Style + + shadow + + Draws + NO + + stroke + + Draws + NO + + + Text + + Align + 0 + Text + {\rtf1\ansi\ansicpg1252\cocoartf1038\cocoasubrtf360 +{\fonttbl\f0\fswiss\fcharset0 Helvetica;} +{\colortbl;\red255\green255\blue255;} +\pard\tx560\tx1120\tx1680\tx2240\tx2800\tx3360\tx3920\tx4480\tx5040\tx5600\tx6160\tx6720\ql\qnatural + +\f0\fs20 \cf0 <<proxies>>} + + Wrap + NO + + + Bounds + {{444, 216.633}, {66, 12}} + Class + ShapedGraphic + FitText + YES + Flow + Resize + ID + 2053 + Shape + Rectangle + Style + + shadow + + Draws + NO + + stroke + + Draws + NO + + + Text + + Align + 0 + Text + {\rtf1\ansi\ansicpg1252\cocoartf1038\cocoasubrtf360 +{\fonttbl\f0\fswiss\fcharset0 Helvetica;} +{\colortbl;\red255\green255\blue255;} +\pard\tx560\tx1120\tx1680\tx2240\tx2800\tx3360\tx3920\tx4480\tx5040\tx5600\tx6160\tx6720\ql\qnatural + +\f0\fs20 \cf0 <<proxies>>} + + Wrap + NO + Class LineGraphic @@ -159,7 +241,7 @@ Head ID - 2042 + 33 ID 2046 @@ -169,8 +251,8 @@ 28.725006103515625 Points - {304, 198.756} {385.25, 157} + {304, 191.818} Style @@ -189,7 +271,7 @@ Tail ID - 33 + 2042 @@ -198,7 +280,7 @@ Head ID - 2043 + 38 ID 2044 @@ -208,8 +290,8 @@ 52.850021362304688 Points - {433.496, 294.6} {454.25, 177} + {442.638, 294.6} Style @@ -228,7 +310,7 @@ Tail ID - 38 + 2043 @@ -1095,7 +1177,7 @@ is_offline_mode()} ModificationDate - 2012-01-24 17:14:19 -0500 + 2012-01-24 17:59:01 -0500 Modifier classic NotesVisible @@ -1167,7 +1249,7 @@ is_offline_mode()} FitInWindow Frame - {{335, 186}, {760, 817}} + {{335, 211}, {760, 817}} ShowRuler ShowStatusBar diff --git a/docs/build/front.rst b/docs/build/front.rst index 0460f350..c3bcaaee 100644 --- a/docs/build/front.rst +++ b/docs/build/front.rst @@ -56,18 +56,25 @@ Upgrading from Alembic 0.1 to 0.2 Alembic 0.2 has some reorganizations and features that might impact an existing 0.1 installation. These include: -* The ``alembic.op`` and ``alembic.context`` names are no longer Python modules, - and are instead objects placed at those names when migrations run. This - means an env.py script or migration script that tries to import from - the object will fail, such as ``from alembic.op import create_table``. - The imports used should now be of the form ``from alembic import context`` - and ``from alembic import op``. The various methods associated with the - context and ops should be invoked from those names now, such as ``op.create_table()``. - The included files and the tutorial in 0.1 already did things this way, - though the examples for each ``op`` docstring did not. Hopefully most users - stuck with the tutorial convention, where the usage examples will - still work without change. - +* The ``alembic.op`` module is now generated from a class called + :class:`.Operations`, including standalone functions that each proxy + to the current instance of :class:`.Operations`. The behavior here + is tailored such that an existing migration script that imports + symbols directly from ``alembic.op``, that is, + ``from alembic.op import create_table``, should still work fine; though ideally + it's better to use the style ``from alembic import op``, then call + migration methods directly from the ``op`` member. The functions inside + of ``alembic.op`` are at the moment minimally tailored proxies; a future + release should refine these to more closely resemble the :class:`.Operations` + methods they represent. +* The ``alembic.context`` module no longer exists, instead ``alembic.context`` + is an object inside the ``alembic`` module which proxies to an underlying + instance of :class:`.EnvironmentContext`. :class:`.EnvironmentContext` + represents the current environment in an encapsulated way. Most ``env.py`` + scripts that don't import from the ``alembic.context`` name directly, + instead importing ``context`` itself, should be fine here. A script that attempts to + import from it, such as ``from alembic.context import configure``, will + need to be changed to read ``from alembic import context; context.configure()``. * The naming convention for migration files is now customizable, and defaults to the scheme "%(rev)s_%(slug)s", where "slug" is based on the message added to the script. When Alembic reads one of these files, it looks diff --git a/docs/build/ops.rst b/docs/build/ops.rst index e9d5bf0c..4322bfb5 100644 --- a/docs/build/ops.rst +++ b/docs/build/ops.rst @@ -14,6 +14,9 @@ All directives exist as methods on a class called :class:`.Operations`. When migration scripts are run, this object is made available to the script via the ``alembic.op`` datamember, which is a *proxy* to an actual instance of :class:`.Operations`. +Currently, ``alembic.op`` is a real Python module, populated +with individual proxies for each method on :class:`.Operations`, +so symbols can be imported safely from the ``alembic.op`` namespace. A key design philosophy to the :mod:`alembic.operations` methods is that to the greatest degree possible, they internally generate the -- 2.47.2