Skip to content
Toggle navigation
Projects
Groups
Snippets
Help
public
/
sequelize
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
0
Merge Requests
0
Pipelines
Wiki
Snippets
Settings
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
不要怂,就是干,撸起袖子干!
Commit 2a7c7c73
authored
Apr 18, 2015
by
Ruben Bridgewater
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Insert missing options / logging passed through to .query
1 parent
a9158201
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
17 additions
and
19 deletions
lib/query-interface.js
test/integration/dialects/postgres/dao.test.js
test/integration/model.test.js
lib/query-interface.js
View file @
2a7c7c7
...
@@ -50,7 +50,7 @@ module.exports = (function() {
...
@@ -50,7 +50,7 @@ module.exports = (function() {
var
showSchemasSql
=
self
.
QueryGenerator
.
showSchemasQuery
();
var
showSchemasSql
=
self
.
QueryGenerator
.
showSchemasQuery
();
return
this
.
sequelize
.
query
(
showSchemasSql
,
options
).
then
(
function
(
schemaNames
)
{
return
this
.
sequelize
.
query
(
showSchemasSql
,
undefined
,
options
).
then
(
function
(
schemaNames
)
{
return
Utils
.
_
.
flatten
(
return
Utils
.
_
.
flatten
(
Utils
.
_
.
map
(
schemaNames
,
function
(
value
)
{
Utils
.
_
.
map
(
schemaNames
,
function
(
value
)
{
return
(
!!
value
.
schema_name
?
value
.
schema_name
:
value
);
return
(
!!
value
.
schema_name
?
value
.
schema_name
:
value
);
...
@@ -150,8 +150,7 @@ module.exports = (function() {
...
@@ -150,8 +150,7 @@ module.exports = (function() {
else
if
(
!!
vals
[
idx
-
1
])
{
else
if
(
!!
vals
[
idx
-
1
])
{
options
.
after
=
vals
[
idx
-
1
];
options
.
after
=
vals
[
idx
-
1
];
}
}
promises
.
push
(
self
.
sequelize
.
query
(
self
.
QueryGenerator
.
pgEnumAdd
(
getTableName
,
keys
[
i
],
value
,
options
),
undefined
,
options
));
promises
.
push
(
self
.
sequelize
.
query
(
self
.
QueryGenerator
.
pgEnumAdd
(
getTableName
,
keys
[
i
],
value
,
options
)));
}
}
});
});
enumIdx
++
;
enumIdx
++
;
...
@@ -245,13 +244,13 @@ module.exports = (function() {
...
@@ -245,13 +244,13 @@ module.exports = (function() {
var
skip
=
options
.
skip
||
[];
var
skip
=
options
.
skip
||
[];
return
self
.
showAllTables
().
then
(
function
(
tableNames
)
{
return
self
.
showAllTables
().
then
(
function
(
tableNames
)
{
if
(
self
.
sequelize
.
options
.
dialect
===
'sqlite'
)
{
if
(
self
.
sequelize
.
options
.
dialect
===
'sqlite'
)
{
return
self
.
sequelize
.
query
(
'PRAGMA foreign_keys;'
).
then
(
function
(
result
)
{
return
self
.
sequelize
.
query
(
'PRAGMA foreign_keys;'
,
undefined
,
options
).
then
(
function
(
result
)
{
var
foreignKeysAreEnabled
=
result
.
foreign_keys
===
1
;
var
foreignKeysAreEnabled
=
result
.
foreign_keys
===
1
;
if
(
foreignKeysAreEnabled
)
{
if
(
foreignKeysAreEnabled
)
{
return
self
.
sequelize
.
query
(
'PRAGMA foreign_keys = OFF'
).
then
(
function
()
{
return
self
.
sequelize
.
query
(
'PRAGMA foreign_keys = OFF'
,
undefined
,
options
).
then
(
function
()
{
return
dropAllTables
(
tableNames
).
then
(
function
()
{
return
dropAllTables
(
tableNames
).
then
(
function
()
{
return
self
.
sequelize
.
query
(
'PRAGMA foreign_keys = ON'
);
return
self
.
sequelize
.
query
(
'PRAGMA foreign_keys = ON'
,
undefined
,
options
);
});
});
});
});
}
else
{
}
else
{
...
@@ -270,7 +269,7 @@ module.exports = (function() {
...
@@ -270,7 +269,7 @@ module.exports = (function() {
foreignKeys
[
normalizedTableName
].
forEach
(
function
(
foreignKey
)
{
foreignKeys
[
normalizedTableName
].
forEach
(
function
(
foreignKey
)
{
var
sql
=
self
.
QueryGenerator
.
dropForeignKeyQuery
(
tableName
,
foreignKey
);
var
sql
=
self
.
QueryGenerator
.
dropForeignKeyQuery
(
tableName
,
foreignKey
);
promises
.
push
(
self
.
sequelize
.
query
(
sql
));
promises
.
push
(
self
.
sequelize
.
query
(
sql
,
undefined
,
options
));
});
});
});
});
...
@@ -325,19 +324,19 @@ module.exports = (function() {
...
@@ -325,19 +324,19 @@ module.exports = (function() {
if
(
typeof
options
===
'string'
)
{
if
(
typeof
options
===
'string'
)
{
schema
=
options
;
schema
=
options
;
}
else
if
(
typeof
options
===
'object'
)
{
}
else
if
(
typeof
options
===
'object'
&&
options
!==
null
)
{
schema
=
options
.
schema
||
null
;
schema
=
options
.
schema
||
null
;
schemaDelimiter
=
options
.
schemaDelimiter
||
null
;
schemaDelimiter
=
options
.
schemaDelimiter
||
null
;
}
}
if
(
typeof
tableName
===
'object'
)
{
if
(
typeof
tableName
===
'object'
&&
tableName
!==
null
)
{
schema
=
tableName
.
schema
;
schema
=
tableName
.
schema
;
tableName
=
tableName
.
tableName
;
tableName
=
tableName
.
tableName
;
}
}
var
sql
=
this
.
QueryGenerator
.
describeTableQuery
(
tableName
,
schema
,
schemaDelimiter
);
var
sql
=
this
.
QueryGenerator
.
describeTableQuery
(
tableName
,
schema
,
schemaDelimiter
);
return
this
.
sequelize
.
query
(
sql
,
{
type
:
QueryTypes
.
DESCRIBE
}).
then
(
function
(
data
)
{
return
this
.
sequelize
.
query
(
sql
,
undefined
,
{
type
:
QueryTypes
.
DESCRIBE
,
logging
:
options
&&
options
.
logging
}).
then
(
function
(
data
)
{
// If no data is returned from the query, then the table name may be wrong.
// If no data is returned from the query, then the table name may be wrong.
// Query generators that use information_schema for retrieving table info will just return an empty result set,
// Query generators that use information_schema for retrieving table info will just return an empty result set,
// it will not throw an error like built-ins do (e.g. DESCRIBE on MySql).
// it will not throw an error like built-ins do (e.g. DESCRIBE on MySql).
...
@@ -704,7 +703,7 @@ module.exports = (function() {
...
@@ -704,7 +703,7 @@ module.exports = (function() {
options
.
plain
=
options
.
plain
===
undefined
?
true
:
options
.
plain
;
options
.
plain
=
options
.
plain
===
undefined
?
true
:
options
.
plain
;
var
sql
=
this
.
QueryGenerator
.
selectQuery
(
tableName
,
options
,
Model
)
var
sql
=
this
.
QueryGenerator
.
selectQuery
(
tableName
,
options
,
Model
)
,
queryOptions
=
Utils
.
_
.
extend
({
transaction
:
options
.
transaction
,
plain
:
options
.
plain
},
{
raw
:
true
,
type
:
QueryTypes
.
SELECT
});
,
queryOptions
=
Utils
.
_
.
extend
({
transaction
:
options
.
transaction
,
plain
:
options
.
plain
,
logging
:
options
.
logging
},
{
raw
:
true
,
type
:
QueryTypes
.
SELECT
});
if
(
attributeSelector
===
undefined
)
{
if
(
attributeSelector
===
undefined
)
{
throw
new
Error
(
'Please pass an attribute selector!'
);
throw
new
Error
(
'Please pass an attribute selector!'
);
...
@@ -835,7 +834,7 @@ module.exports = (function() {
...
@@ -835,7 +834,7 @@ module.exports = (function() {
var
sql
=
this
.
QueryGenerator
.
setAutocommitQuery
(
value
,
options
);
var
sql
=
this
.
QueryGenerator
.
setAutocommitQuery
(
value
,
options
);
if
(
sql
)
{
if
(
sql
)
{
return
this
.
sequelize
.
query
(
sql
,
null
,
{
transaction
:
transaction
});
return
this
.
sequelize
.
query
(
sql
,
null
,
{
transaction
:
transaction
,
logging
:
options
.
logging
});
}
else
{
}
else
{
return
Promise
.
resolve
();
return
Promise
.
resolve
();
}
}
...
@@ -853,7 +852,7 @@ module.exports = (function() {
...
@@ -853,7 +852,7 @@ module.exports = (function() {
var
sql
=
this
.
QueryGenerator
.
setIsolationLevelQuery
(
value
,
options
);
var
sql
=
this
.
QueryGenerator
.
setIsolationLevelQuery
(
value
,
options
);
if
(
sql
)
{
if
(
sql
)
{
return
this
.
sequelize
.
query
(
sql
,
null
,
{
transaction
:
transaction
});
return
this
.
sequelize
.
query
(
sql
,
null
,
{
transaction
:
transaction
,
logging
:
options
.
logging
});
}
else
{
}
else
{
return
Promise
.
resolve
();
return
Promise
.
resolve
();
}
}
...
...
test/integration/dialects/postgres/dao.test.js
View file @
2a7c7c7
...
@@ -382,17 +382,16 @@ if (dialect.match(/^postgres/)) {
...
@@ -382,17 +382,16 @@ if (dialect.match(/^postgres/)) {
return
User
.
sync
({
return
User
.
sync
({
logging
:
function
(
sql
)
{
logging
:
function
(
sql
)
{
console
.
log
(
sql
);
if
(
sql
.
indexOf
(
'neutral'
)
>
-
1
)
{
if
(
sql
.
indexOf
(
'neutral'
)
>
-
1
)
{
expect
(
sql
).
to
.
equal
(
"ALTER TYPE \"enum_UserEnums_mood\" ADD VALUE 'neutral' BEFORE 'happy'"
);
expect
(
sql
.
indexOf
(
"ALTER TYPE \"enum_UserEnums_mood\" ADD VALUE 'neutral' BEFORE 'happy'"
)).
to
.
not
.
be
.
equal
(
-
1
);
count
++
;
count
++
;
}
}
else
if
(
sql
.
indexOf
(
'ecstatic'
)
>
-
1
)
{
else
if
(
sql
.
indexOf
(
'ecstatic'
)
>
-
1
)
{
expect
(
sql
).
to
.
equal
(
"ALTER TYPE \"enum_UserEnums_mood\" ADD VALUE 'ecstatic' BEFORE 'meh'"
);
expect
(
sql
.
indexOf
(
"ALTER TYPE \"enum_UserEnums_mood\" ADD VALUE 'ecstatic' BEFORE 'meh'"
)).
to
.
not
.
be
.
equal
(
-
1
);
count
++
;
count
++
;
}
}
else
if
(
sql
.
indexOf
(
'joyful'
)
>
-
1
)
{
else
if
(
sql
.
indexOf
(
'joyful'
)
>
-
1
)
{
expect
(
sql
).
to
.
equal
(
"ALTER TYPE \"enum_UserEnums_mood\" ADD VALUE 'joyful' AFTER 'meh'"
);
expect
(
sql
.
indexOf
(
"ALTER TYPE \"enum_UserEnums_mood\" ADD VALUE 'joyful' AFTER 'meh'"
)).
to
.
not
.
be
.
equal
(
-
1
);
count
++
;
count
++
;
}
}
}
}
...
...
test/integration/model.test.js
View file @
2a7c7c7
...
@@ -1586,7 +1586,7 @@ describe(Support.getTestDialectTeaser('Model'), function() {
...
@@ -1586,7 +1586,7 @@ describe(Support.getTestDialectTeaser('Model'), function() {
return
this
.
User
.
count
({
return
this
.
User
.
count
({
logging
:
function
(
sql
)
{
logging
:
function
(
sql
)
{
test
=
true
;
test
=
true
;
expect
(
sql
).
not
.
to
.
exist
;
expect
(
sql
).
to
.
exist
;
expect
(
sql
.
toUpperCase
().
indexOf
(
'SELECT'
)).
to
.
be
.
above
(
-
1
);
expect
(
sql
.
toUpperCase
().
indexOf
(
'SELECT'
)).
to
.
be
.
above
(
-
1
);
}
}
}).
then
(
function
()
{
}).
then
(
function
()
{
...
@@ -1679,7 +1679,7 @@ describe(Support.getTestDialectTeaser('Model'), function() {
...
@@ -1679,7 +1679,7 @@ describe(Support.getTestDialectTeaser('Model'), function() {
return
this
.
UserWithAge
.
min
(
'age'
,
{
return
this
.
UserWithAge
.
min
(
'age'
,
{
logging
:
function
(
sql
)
{
logging
:
function
(
sql
)
{
test
=
true
;
test
=
true
;
expect
(
sql
).
not
.
to
.
exist
;
expect
(
sql
).
to
.
exist
;
expect
(
sql
.
toUpperCase
().
indexOf
(
'SELECT'
)).
to
.
be
.
above
(
-
1
);
expect
(
sql
.
toUpperCase
().
indexOf
(
'SELECT'
)).
to
.
be
.
above
(
-
1
);
}
}
}).
then
(
function
()
{
}).
then
(
function
()
{
...
...
Write
Preview
Markdown
is supported
Attach a file
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to post a comment