Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
f41211f9
Commit
f41211f9
authored
Oct 04, 2004
by
joreland@mysql.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wl2135 - ndb api test prg
parent
fd420f72
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
276 additions
and
21 deletions
+276
-21
ndb/test/include/NDBT_ResultRow.hpp
ndb/test/include/NDBT_ResultRow.hpp
+3
-2
ndb/test/include/UtilTransactions.hpp
ndb/test/include/UtilTransactions.hpp
+15
-4
ndb/test/src/NDBT_ResultRow.cpp
ndb/test/src/NDBT_ResultRow.cpp
+5
-1
ndb/test/src/UtilTransactions.cpp
ndb/test/src/UtilTransactions.cpp
+253
-14
No files found.
ndb/test/include/NDBT_ResultRow.hpp
View file @
f41211f9
...
@@ -24,7 +24,8 @@ public:
...
@@ -24,7 +24,8 @@ public:
NDBT_ResultRow
(
const
NdbDictionary
::
Table
&
tab
,
char
attrib_delimiter
=
'\t'
);
NDBT_ResultRow
(
const
NdbDictionary
::
Table
&
tab
,
char
attrib_delimiter
=
'\t'
);
~
NDBT_ResultRow
();
~
NDBT_ResultRow
();
NdbRecAttr
*
&
attributeStore
(
int
i
);
NdbRecAttr
*
&
attributeStore
(
int
i
);
const
NdbRecAttr
*
attributeStore
(
const
char
*
name
);
const
NdbRecAttr
*
attributeStore
(
int
i
)
const
;
const
NdbRecAttr
*
attributeStore
(
const
char
*
name
)
const
;
BaseString
c_str
();
BaseString
c_str
();
...
...
ndb/test/include/UtilTransactions.hpp
View file @
f41211f9
...
@@ -87,19 +87,30 @@ private:
...
@@ -87,19 +87,30 @@ private:
int
verifyUniqueIndex
(
Ndb
*
,
int
verifyUniqueIndex
(
Ndb
*
,
const
char
*
indexName
,
const
NdbDictionary
::
Index
*
,
int
parallelism
=
0
,
int
parallelism
=
0
,
bool
transactional
=
false
);
bool
transactional
=
false
);
int
scanAndCompareUniqueIndex
(
Ndb
*
pNdb
,
int
scanAndCompareUniqueIndex
(
Ndb
*
pNdb
,
const
char
*
indexName
,
const
NdbDictionary
::
Index
*
,
int
parallelism
,
int
parallelism
,
bool
transactional
);
bool
transactional
);
int
readRowFromTableAndIndex
(
Ndb
*
pNdb
,
int
readRowFromTableAndIndex
(
Ndb
*
pNdb
,
NdbConnection
*
pTrans
,
NdbConnection
*
pTrans
,
const
char
*
indexName
,
const
NdbDictionary
::
Index
*
,
NDBT_ResultRow
&
row
);
NDBT_ResultRow
&
row
);
int
verifyOrderedIndex
(
Ndb
*
,
const
NdbDictionary
::
Index
*
,
int
parallelism
=
0
,
bool
transactional
=
false
);
int
get_values
(
NdbOperation
*
op
,
NDBT_ResultRow
&
dst
);
int
equal
(
const
NdbDictionary
::
Table
*
,
NdbOperation
*
,
const
NDBT_ResultRow
&
);
int
equal
(
const
NdbDictionary
::
Index
*
,
NdbOperation
*
,
const
NDBT_ResultRow
&
);
protected:
protected:
int
m_defaultClearMethod
;
int
m_defaultClearMethod
;
const
NdbDictionary
::
Table
&
tab
;
const
NdbDictionary
::
Table
&
tab
;
...
...
ndb/test/src/NDBT_ResultRow.cpp
View file @
f41211f9
...
@@ -58,10 +58,14 @@ NDBT_ResultRow::attributeStore(int i){
...
@@ -58,10 +58,14 @@ NDBT_ResultRow::attributeStore(int i){
return
data
[
i
];
return
data
[
i
];
}
}
const
NdbRecAttr
*
NDBT_ResultRow
::
attributeStore
(
int
i
)
const
{
return
data
[
i
];
}
const
const
NdbRecAttr
*
NdbRecAttr
*
NDBT_ResultRow
::
attributeStore
(
const
char
*
name
){
NDBT_ResultRow
::
attributeStore
(
const
char
*
name
)
const
{
for
(
int
i
=
0
;
i
<
cols
;
i
++
){
for
(
int
i
=
0
;
i
<
cols
;
i
++
){
if
(
strcmp
(
names
[
i
],
name
)
==
0
)
if
(
strcmp
(
names
[
i
],
name
)
==
0
)
return
data
[
i
];
return
data
[
i
];
...
...
ndb/test/src/UtilTransactions.cpp
View file @
f41211f9
...
@@ -857,8 +857,9 @@ UtilTransactions::verifyIndex(Ndb* pNdb,
...
@@ -857,8 +857,9 @@ UtilTransactions::verifyIndex(Ndb* pNdb,
switch
(
pIndex
->
getType
()){
switch
(
pIndex
->
getType
()){
case
NdbDictionary
:
:
Index
::
UniqueHashIndex
:
case
NdbDictionary
:
:
Index
::
UniqueHashIndex
:
return
verifyUniqueIndex
(
pNdb
,
pIndex
,
parallelism
,
transactional
);
case
NdbDictionary
:
:
Index
::
OrderedIndex
:
case
NdbDictionary
:
:
Index
::
OrderedIndex
:
return
verify
UniqueIndex
(
pNdb
,
indexName
,
parallelism
,
transactional
);
return
verify
OrderedIndex
(
pNdb
,
pIndex
,
parallelism
,
transactional
);
break
;
break
;
default:
default:
ndbout
<<
"Unknown index type"
<<
endl
;
ndbout
<<
"Unknown index type"
<<
endl
;
...
@@ -870,7 +871,7 @@ UtilTransactions::verifyIndex(Ndb* pNdb,
...
@@ -870,7 +871,7 @@ UtilTransactions::verifyIndex(Ndb* pNdb,
int
int
UtilTransactions
::
verifyUniqueIndex
(
Ndb
*
pNdb
,
UtilTransactions
::
verifyUniqueIndex
(
Ndb
*
pNdb
,
const
char
*
indexName
,
const
NdbDictionary
::
Index
*
pIndex
,
int
parallelism
,
int
parallelism
,
bool
transactional
){
bool
transactional
){
...
@@ -882,7 +883,7 @@ UtilTransactions::verifyUniqueIndex(Ndb* pNdb,
...
@@ -882,7 +883,7 @@ UtilTransactions::verifyUniqueIndex(Ndb* pNdb,
*/
*/
if
(
scanAndCompareUniqueIndex
(
pNdb
,
if
(
scanAndCompareUniqueIndex
(
pNdb
,
indexName
,
pIndex
,
parallelism
,
parallelism
,
transactional
)
!=
NDBT_OK
){
transactional
)
!=
NDBT_OK
){
return
NDBT_FAILED
;
return
NDBT_FAILED
;
...
@@ -896,7 +897,7 @@ UtilTransactions::verifyUniqueIndex(Ndb* pNdb,
...
@@ -896,7 +897,7 @@ UtilTransactions::verifyUniqueIndex(Ndb* pNdb,
int
int
UtilTransactions
::
scanAndCompareUniqueIndex
(
Ndb
*
pNdb
,
UtilTransactions
::
scanAndCompareUniqueIndex
(
Ndb
*
pNdb
,
const
char
*
indexName
,
const
NdbDictionary
::
Index
*
pIndex
,
int
parallelism
,
int
parallelism
,
bool
transactional
){
bool
transactional
){
...
@@ -996,7 +997,7 @@ UtilTransactions::scanAndCompareUniqueIndex(Ndb* pNdb,
...
@@ -996,7 +997,7 @@ UtilTransactions::scanAndCompareUniqueIndex(Ndb* pNdb,
if
(
readRowFromTableAndIndex
(
pNdb
,
if
(
readRowFromTableAndIndex
(
pNdb
,
pTrans
,
pTrans
,
indexName
,
pIndex
,
row
)
!=
NDBT_OK
){
row
)
!=
NDBT_OK
){
pNdb
->
closeTransaction
(
pTrans
);
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
return
NDBT_FAILED
;
...
@@ -1027,15 +1028,9 @@ UtilTransactions::scanAndCompareUniqueIndex(Ndb* pNdb,
...
@@ -1027,15 +1028,9 @@ UtilTransactions::scanAndCompareUniqueIndex(Ndb* pNdb,
int
int
UtilTransactions
::
readRowFromTableAndIndex
(
Ndb
*
pNdb
,
UtilTransactions
::
readRowFromTableAndIndex
(
Ndb
*
pNdb
,
NdbConnection
*
scanTrans
,
NdbConnection
*
scanTrans
,
const
char
*
indexName
,
const
NdbDictionary
::
Index
*
pIndex
,
NDBT_ResultRow
&
row
){
NDBT_ResultRow
&
row
){
const
NdbDictionary
::
Index
*
pIndex
=
pNdb
->
getDictionary
()
->
getIndex
(
indexName
,
tab
.
getName
());
if
(
pIndex
==
0
){
ndbout
<<
" Index "
<<
indexName
<<
" does not exist!"
<<
endl
;
return
NDBT_FAILED
;
}
NdbDictionary
::
Index
::
Type
indexType
=
pIndex
->
getType
();
NdbDictionary
::
Index
::
Type
indexType
=
pIndex
->
getType
();
int
retryAttempt
=
0
;
int
retryAttempt
=
0
;
...
@@ -1050,7 +1045,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb,
...
@@ -1050,7 +1045,7 @@ UtilTransactions::readRowFromTableAndIndex(Ndb* pNdb,
// Allocate place to store the result
// Allocate place to store the result
NDBT_ResultRow
tabRow
(
tab
);
NDBT_ResultRow
tabRow
(
tab
);
NDBT_ResultRow
indexRow
(
tab
);
NDBT_ResultRow
indexRow
(
tab
);
const
char
*
indexName
=
pIndex
->
getName
();
while
(
true
){
while
(
true
){
if
(
retryAttempt
)
if
(
retryAttempt
)
...
@@ -1281,3 +1276,247 @@ close_all:
...
@@ -1281,3 +1276,247 @@ close_all:
return
return_code
;
return
return_code
;
}
}
int
UtilTransactions
::
verifyOrderedIndex
(
Ndb
*
pNdb
,
const
NdbDictionary
::
Index
*
pIndex
,
int
parallelism
,
bool
transactional
){
int
retryAttempt
=
0
;
const
int
retryMax
=
100
;
int
check
;
NdbConnection
*
pTrans
;
NdbScanOperation
*
pOp
;
NdbIndexScanOperation
*
iop
=
0
;
NdbResultSet
*
cursor
=
0
;
NDBT_ResultRow
scanRow
(
tab
);
NDBT_ResultRow
pkRow
(
tab
);
NDBT_ResultRow
indexRow
(
tab
);
const
char
*
indexName
=
pIndex
->
getName
();
int
res
;
parallelism
=
1
;
while
(
true
){
if
(
retryAttempt
>=
retryMax
){
g_info
<<
"ERROR: has retried this operation "
<<
retryAttempt
<<
" times, failing!"
<<
endl
;
return
NDBT_FAILED
;
}
pTrans
=
pNdb
->
startTransaction
();
if
(
pTrans
==
NULL
)
{
const
NdbError
err
=
pNdb
->
getNdbError
();
if
(
err
.
status
==
NdbError
::
TemporaryError
){
ERR
(
err
);
NdbSleep_MilliSleep
(
50
);
retryAttempt
++
;
continue
;
}
ERR
(
err
);
return
NDBT_FAILED
;
}
pOp
=
pTrans
->
getNdbScanOperation
(
tab
.
getName
());
if
(
pOp
==
NULL
)
{
ERR
(
pTrans
->
getNdbError
());
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
}
NdbResultSet
*
rs
;
if
(
transactional
){
rs
=
pOp
->
readTuples
(
NdbScanOperation
::
LM_Read
,
0
,
parallelism
);
}
else
{
rs
=
pOp
->
readTuples
(
NdbScanOperation
::
LM_CommittedRead
,
0
,
parallelism
);
}
if
(
rs
==
0
)
{
ERR
(
pTrans
->
getNdbError
());
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
}
check
=
pOp
->
interpret_exit_ok
();
if
(
check
==
-
1
)
{
ERR
(
pTrans
->
getNdbError
());
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
}
if
(
get_values
(
pOp
,
scanRow
))
{
abort
();
}
check
=
pTrans
->
execute
(
NoCommit
);
if
(
check
==
-
1
)
{
const
NdbError
err
=
pTrans
->
getNdbError
();
if
(
err
.
status
==
NdbError
::
TemporaryError
){
ERR
(
err
);
pNdb
->
closeTransaction
(
pTrans
);
NdbSleep_MilliSleep
(
50
);
retryAttempt
++
;
continue
;
}
ERR
(
err
);
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
}
int
eof
;
int
rows
=
0
;
while
(
check
==
0
&&
(
eof
=
rs
->
nextResult
())
==
0
){
ndbout_c
(
"Row: %d"
,
rows
);
rows
++
;
bool
null_found
=
false
;
for
(
int
a
=
0
;
a
<
(
int
)
pIndex
->
getNoOfColumns
();
a
++
){
const
NdbDictionary
::
Column
*
col
=
pIndex
->
getColumn
(
a
);
if
(
scanRow
.
attributeStore
(
col
->
getName
())
->
isNULL
())
{
null_found
=
true
;
break
;
}
}
// Do pk lookup
NdbOperation
*
pk
=
pTrans
->
getNdbOperation
(
tab
.
getName
());
if
(
!
pk
||
pk
->
readTuple
())
goto
error
;
if
(
equal
(
&
tab
,
pk
,
scanRow
)
||
get_values
(
pk
,
pkRow
))
goto
error
;
if
(
!
null_found
)
{
if
(
!
iop
&&
(
iop
=
pTrans
->
getNdbIndexScanOperation
(
indexName
,
tab
.
getName
())))
{
cursor
=
iop
->
readTuples
(
transactional
?
NdbScanOperation
::
LM_Read
:
NdbScanOperation
::
LM_CommittedRead
,
parallelism
);
iop
->
interpret_exit_ok
();
if
(
!
cursor
||
get_values
(
iop
,
indexRow
))
goto
error
;
}
else
if
(
!
iop
||
iop
->
reset_bounds
())
{
goto
error
;
}
if
(
equal
(
pIndex
,
iop
,
scanRow
))
goto
error
;
else
ndbout_c
(
"equal ok"
);
}
check
=
pTrans
->
execute
(
Commit
);
// commit pk read
if
(
check
)
goto
error
;
if
(
scanRow
.
c_str
()
!=
pkRow
.
c_str
()){
g_err
<<
"Error when comapring records"
<<
endl
;
g_err
<<
" scanRow:
\n
"
<<
scanRow
.
c_str
().
c_str
()
<<
endl
;
g_err
<<
" pkRow:
\n
"
<<
pkRow
.
c_str
().
c_str
()
<<
endl
;
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
}
if
(
!
null_found
)
{
if
((
res
=
cursor
->
nextResult
())
!=
0
){
g_err
<<
"Failed to find row using index: "
<<
res
<<
endl
;
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
}
if
(
scanRow
.
c_str
()
!=
indexRow
.
c_str
()){
g_err
<<
"Error when comapring records"
<<
endl
;
g_err
<<
" scanRow:
\n
"
<<
scanRow
.
c_str
().
c_str
()
<<
endl
;
g_err
<<
" indexRow:
\n
"
<<
indexRow
.
c_str
().
c_str
()
<<
endl
;
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
}
if
(
cursor
->
nextResult
()
==
0
){
g_err
<<
"Found extra row!!"
<<
endl
;
g_err
<<
" indexRow:
\n
"
<<
indexRow
.
c_str
().
c_str
()
<<
endl
;
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
}
}
pTrans
->
restart
();
ndbout_c
(
"row %d ok"
,
rows
-
1
);
}
if
(
eof
==
-
1
||
check
==
-
1
)
{
error:
const
NdbError
err
=
pTrans
->
getNdbError
();
if
(
err
.
status
==
NdbError
::
TemporaryError
){
ERR
(
err
);
pNdb
->
closeTransaction
(
pTrans
);
NdbSleep_MilliSleep
(
50
);
retryAttempt
++
;
rows
--
;
continue
;
}
ERR
(
err
);
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_FAILED
;
}
pNdb
->
closeTransaction
(
pTrans
);
return
NDBT_OK
;
}
return
NDBT_FAILED
;
}
int
UtilTransactions
::
get_values
(
NdbOperation
*
op
,
NDBT_ResultRow
&
dst
)
{
for
(
int
a
=
0
;
a
<
tab
.
getNoOfColumns
();
a
++
){
NdbRecAttr
*&
ref
=
dst
.
attributeStore
(
a
);
if
((
ref
=
op
->
getValue
(
a
))
==
0
)
{
return
NDBT_FAILED
;
}
}
return
0
;
}
int
UtilTransactions
::
equal
(
const
NdbDictionary
::
Index
*
pIndex
,
NdbOperation
*
op
,
const
NDBT_ResultRow
&
src
)
{
for
(
Uint32
a
=
0
;
a
<
pIndex
->
getNoOfColumns
();
a
++
){
const
NdbDictionary
::
Column
*
col
=
pIndex
->
getColumn
(
a
);
if
(
op
->
equal
(
col
->
getName
(),
src
.
attributeStore
(
col
->
getName
())
->
aRef
())
!=
0
){
return
NDBT_FAILED
;
}
}
return
0
;
}
int
UtilTransactions
::
equal
(
const
NdbDictionary
::
Table
*
pTable
,
NdbOperation
*
op
,
const
NDBT_ResultRow
&
src
)
{
for
(
Uint32
a
=
0
;
a
<
tab
.
getNoOfColumns
();
a
++
){
const
NdbDictionary
::
Column
*
attr
=
tab
.
getColumn
(
a
);
if
(
attr
->
getPrimaryKey
()
==
true
){
if
(
op
->
equal
(
attr
->
getName
(),
src
.
attributeStore
(
a
)
->
aRef
())
!=
0
){
return
NDBT_FAILED
;
}
}
}
return
0
;
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
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 comment