2011-07-20 17:19:27 +00:00
|
|
|
#
|
|
|
|
|
# spec file for package python-SQLAlchemy
|
|
|
|
|
#
|
2019-02-09 16:25:41 +00:00
|
|
|
# Copyright (c) 2019 SUSE LINUX GmbH, Nuernberg, Germany.
|
2011-07-20 17:19:27 +00:00
|
|
|
#
|
|
|
|
|
# All modifications and additions to the file contributed by third parties
|
|
|
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
|
|
|
# upon. The license for this file, and modifications and additions to the
|
|
|
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
|
|
|
# license for the pristine package is not an Open Source License, in which
|
|
|
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
|
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
|
|
|
# published by the Open Source Initiative.
|
2011-08-04 13:01:18 +00:00
|
|
|
|
2018-09-26 03:25:09 +00:00
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
2011-07-20 17:19:27 +00:00
|
|
|
#
|
|
|
|
|
|
2011-08-04 13:01:18 +00:00
|
|
|
|
2017-04-18 16:10:52 +00:00
|
|
|
%{?!python_module:%define python_module() python-%{**} python3-%{**}}
|
2017-05-01 19:00:13 +00:00
|
|
|
%define oldpython python
|
2011-07-20 17:19:27 +00:00
|
|
|
Name: python-SQLAlchemy
|
Accepting request 717941 from home:TheBlackCat:branches:devel:languages:python
- update to version 1.3.6
+ orm
* [feature] Added new loader option method Load.options()
which allows loader options to be constructed hierarchically,
so that many sub-options can be applied to a particular path
without needing to call defaultload() many times.
* [bug] Fixed regression caused by #4365 where a join from an
entity to itself without using aliases no longer raises an
informative error message, instead failing on an assertion.
The informative error condition has been restored.
* [bug] Fixed an issue where the orm._ORMJoin.join() method,
which is a not-internally-used ORM-level method that exposes
what is normally an internal process of Query.join(), did
not propagate the full and outerjoin keyword arguments
correctly.
* [bug] Fixed bug where a many-to-one relationship that
specified uselist=True would fail to update correctly during
a primary key change where a related column needs to change.
* [bug] Fixed bug where the detection for many-to-one or
one-to-one use with a “dynamic” relationship, which is an
invalid configuration, would fail to raise if the
relationship were configured with uselist=True. The current
fix is that it warns, instead of raises, as this would
otherwise be backwards incompatible, however in a future
release it will be a raise.
* [bug] Fixed bug where a synonym created against a mapped
attribute that does not exist yet, as is the case when it
refers to backref before mappers are configured, would raise
recursion errors when trying to test for attributes on it
which ultimately don’t exist (as occurs when the classes are
run through Sphinx autodoc), as the unconfigured state of
the synonym would put it into an attribute not found loop.
* [performance] The optimzation applied to selectin loading
in #4340 where a JOIN is not needed to eagerly load related
items is now applied to many-to-one relationships as well,
so that only the related table is queried for a simple join
condition. In this case, the related items are queried based
on the value of a foreign key column on the parent; if these
columns are deferred or otherwise not loaded on any of the
parent objects in the collection, the loader falls back to the
JOIN method.
+ engine
* [bug] Fixed bug where using reflection function such as
MetaData.reflect() with an Engine object that had execution
options applied to it would fail, as the resulting
OptionEngine proxy object failed to include a .engine
attribute used within the reflection routines.
+ sql
* [bug] Adjusted the initialization for Enum to minimize how
often it invokes the .__members__ attribute of a given
PEP-435 enumeration object, to suit the case where this
attribute is expensive to invoke, as is the case for some
popular third party enumeration libraries.
* [bug] [postgresql] Fixed issue where the array_agg construct
in combination with FunctionElement.filter() would not
produce the correct operator precedence in combination
with the array index operator.
* [bug] Fixed an unlikely issue where the “corresponding
column” routine for unions and other CompoundSelect objects
could return the wrong column in some overlapping column
situtations, thus potentially impacting some ORM operations
when set operations are in use, if the underlying select()
constructs were used previously in other similar kinds of
routines, due to a cached value not being cleared.
+ postgresql
* [usecase] Added support for reflection of indexes on
PostgreSQL partitioned tables, which was added to PostgreSQL
as of version 11.
* [usecase] Added support for multidimensional Postgresql array
literals via nesting the postgresql.array object within
another one. The multidimensional array type is detected
automatically.
+ mysql
* [bug] Fixed bug where the special logic to render “NULL” for
the TIMESTAMP datatype when nullable=True would not work if the
column’s datatype were a TypeDecorator or a Variant. The logic
now ensures that it unwraps down to the original TIMESTAMP so
that this special case NULL keyword is correctly rendered when
requested.
* [bug] Enhanced MySQL/MariaDB version string parsing to
accommodate for exotic MariaDB version strings where the
“MariaDB” word is embedded among other alphanumeric
characters such as “MariaDBV1”. This detection is critical
in order to correctly accommodate for API features that have
split between MySQL and MariaDB such as the
“transaction_isolation” system variable.
+ sqlite
* [usecase] Added support for composite (tuple) IN operators
with SQLite, by rendering the VALUES keyword for this backend.
As other backends such as DB2 are known to use the same syntax,
the syntax is enabled in the base compiler using a dialect-level
flag tuple_in_values. The change also includes support for
“empty IN tuple” expressions for SQLite when using “in_()”
between a tuple value and an empty set.
+ mssql
* [bug] Ensured that the queries used to reflect indexes and
view definitions will explicitly CAST string parameters into
NVARCHAR, as many SQL Server drivers frequently treat string
values, particularly those with non-ascii characters or
larger string values, as TEXT which often don’t compare
correctly against VARCHAR characters in SQL Server’s
information schema tables for some reason. These CAST
operations already take place for reflection queries against
SQL Server information_schema. tables but were missing from
three additional queries that are against sys.tables.
OBS-URL: https://build.opensuse.org/request/show/717941
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-SQLAlchemy?expand=0&rev=145
2019-07-23 15:54:29 +00:00
|
|
|
Version: 1.3.6
|
2011-09-21 12:42:28 +00:00
|
|
|
Release: 0
|
2011-07-20 17:19:27 +00:00
|
|
|
Summary: Database Abstraction Library
|
2011-12-06 17:57:50 +00:00
|
|
|
License: MIT
|
2011-07-20 17:19:27 +00:00
|
|
|
Group: Development/Languages/Python
|
2018-04-21 19:41:16 +00:00
|
|
|
URL: http://www.sqlalchemy.org
|
2016-09-15 23:29:32 +00:00
|
|
|
Source: https://files.pythonhosted.org/packages/source/S/SQLAlchemy/SQLAlchemy-%{version}.tar.gz
|
2019-02-23 15:03:43 +00:00
|
|
|
# devel is needed for optional C extensions cprocessors.so, cresultproxy.so and cutils.so
|
|
|
|
|
BuildRequires: %{python_module devel}
|
|
|
|
|
BuildRequires: %{python_module setuptools}
|
2019-03-06 13:40:49 +00:00
|
|
|
BuildRequires: fdupes
|
|
|
|
|
BuildRequires: python-rpm-macros
|
|
|
|
|
Provides: python-sqlalchemy = %{version}
|
|
|
|
|
Obsoletes: python-sqlalchemy < %{version}
|
2019-02-23 15:03:43 +00:00
|
|
|
# SECTION test requirements
|
2018-01-03 06:46:12 +00:00
|
|
|
BuildRequires: %{python_module mock}
|
|
|
|
|
BuildRequires: %{python_module pytest-xdist}
|
2017-04-18 16:10:52 +00:00
|
|
|
BuildRequires: %{python_module pytest}
|
2019-02-23 15:03:43 +00:00
|
|
|
# /SECTION
|
2017-05-01 19:00:13 +00:00
|
|
|
%ifpython2
|
|
|
|
|
Obsoletes: %{oldpython}-sqlalchemy < %{version}
|
|
|
|
|
Provides: %{oldpython}-sqlalchemy = %{version}
|
|
|
|
|
%endif
|
2017-04-18 16:10:52 +00:00
|
|
|
%python_subpackages
|
2011-07-20 17:19:27 +00:00
|
|
|
|
|
|
|
|
%description
|
|
|
|
|
SQLAlchemy is an Object Relational Mappper (ORM) that provides a flexible,
|
|
|
|
|
high-level interface to SQL databases. Database and domain concepts are
|
|
|
|
|
decoupled, allowing both sides maximum flexibility and power. SQLAlchemy
|
|
|
|
|
provides a powerful mapping layer that can work as automatically or as manually
|
|
|
|
|
as you choose, determining relationships based on foreign keys or letting you
|
|
|
|
|
define the join conditions explicitly, to bridge the gap between database and
|
|
|
|
|
domain.
|
|
|
|
|
|
2017-04-18 16:10:52 +00:00
|
|
|
%package -n %{name}-doc
|
2011-07-20 17:19:27 +00:00
|
|
|
Summary: Documentation for python-SQLAlchemy
|
|
|
|
|
Group: Documentation/Other
|
2019-03-06 13:40:49 +00:00
|
|
|
Provides: %{python_module SQLAlchemy-doc = %{version}}
|
2013-01-02 18:02:50 +00:00
|
|
|
BuildArch: noarch
|
2011-07-20 17:19:27 +00:00
|
|
|
|
2017-04-18 16:10:52 +00:00
|
|
|
%description -n %{name}-doc
|
2011-07-20 17:19:27 +00:00
|
|
|
This package contains HTML documentation, including tutorials and API
|
|
|
|
|
reference for python-SQLAlchemy.
|
|
|
|
|
|
|
|
|
|
%prep
|
|
|
|
|
%setup -q -n SQLAlchemy-%{version}
|
|
|
|
|
rm -rf doc/build # Remove unnecessary scripts for building documentation
|
|
|
|
|
sed -i 's/\r$//' examples/dynamic_dict/dynamic_dict.py
|
|
|
|
|
|
|
|
|
|
%build
|
2017-04-18 16:10:52 +00:00
|
|
|
export CFLAGS="%{optflags} -fno-strict-aliasing"
|
|
|
|
|
%python_build
|
2011-07-20 17:19:27 +00:00
|
|
|
|
|
|
|
|
%install
|
2017-04-18 16:10:52 +00:00
|
|
|
%python_install
|
|
|
|
|
%python_expand %fdupes %{buildroot}%{$python_sitearch}
|
2011-07-20 17:19:27 +00:00
|
|
|
|
2011-09-21 12:42:28 +00:00
|
|
|
%check
|
2019-04-10 19:10:10 +00:00
|
|
|
%pytest
|
2011-07-20 17:19:27 +00:00
|
|
|
|
2017-04-18 16:10:52 +00:00
|
|
|
%files %{python_files}
|
Accepting request 594666 from home:apersaud:branches:devel:languages:python
- specfile:
* run spec-cleaner
- update to version 1.2.6:
* orm
+ [orm] [bug] Fixed bug where using Mutable.associate_with() or
Mutable.as_mutable() in conjunction with a class that has non-
primary mappers set up with alternatively-named attributes would
produce an attribute error. Since non-primary mappers are not
used for persistence, the mutable extension now excludes
non-primary mappers from its instrumentation steps. References:
#4215
* engine
+ [engine] [bug] Fixed bug in connection pool where a connection
could be present in the pool without all of its “connect” event
handlers called, if a previous “connect” handler threw an
exception; note that the dialects themselves have connect
handlers that emit SQL, such as those which set transaction
isolation, which can fail if the database is in a non-available
state, but still allows a connection. The connection is now
invalidated first if any of the connect handlers fail.
References: #4225
* sql
+ [sql] [bug] Fixed a regression that occurred from the previous
fix to #4204 in version 1.2.5, where a CTE that refers to itself
after the CTE.alias() method has been called would not refer to
iself correctly. References: #4204
* postgresql
+ [postgresql] [feature] Added support for “PARTITION BY” in
Postgresql table definitions, using
“postgresql_partition_by”. Pull request courtesy Vsevolod
Solovyov.
* mssql
+ [mssql] [bug] Adjusted the SQL Server version detection for
pyodbc to only allow for numeric tokens, filtering out
non-integers, since the dialect does tuple- numeric comparisons
with this value. This is normally true for all known SQL Server
/ pyodbc drivers in any case. References: #4227
* oracle
+ [oracle] [bug] The minimum cx_Oracle version supported is 5.2
(June 2015). Previously, the dialect asserted against version
5.0 but as of 1.2.2 we are using some symbols that did not
appear until 5.2. References: #4211
* misc
+ [bug] [declarative] Removed a warning that would be emitted when
calling upon __table_args__, __mapper_args__ as named with a
@declared_attr method, when called from a non-mapped declarative
mixin. Calling these directly is documented as the approach to
use when one is overidding one of these methods on a mapped
class. The warning still emits for regular attribute names.
References: #4221
OBS-URL: https://build.opensuse.org/request/show/594666
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-SQLAlchemy?expand=0&rev=108
2018-04-08 17:58:08 +00:00
|
|
|
%license LICENSE
|
|
|
|
|
%doc CHANGES README.rst README.dialects.rst README.unittests.rst
|
2012-05-23 07:27:03 +00:00
|
|
|
%{python_sitearch}/sqlalchemy/
|
|
|
|
|
%{python_sitearch}/SQLAlchemy-%{version}-py%{py_ver}.egg-info
|
2011-07-20 17:19:27 +00:00
|
|
|
|
2017-04-18 16:10:52 +00:00
|
|
|
%files -n %{name}-doc
|
|
|
|
|
%doc doc/
|
|
|
|
|
%doc examples/
|
2011-07-20 17:19:27 +00:00
|
|
|
|
|
|
|
|
%changelog
|