Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
W
wendelin
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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Boxiang Sun
wendelin
Commits
501d29e9
Commit
501d29e9
authored
Jul 01, 2015
by
Ivan Tyagov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactor and extend test
parent
243137fe
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
86 additions
and
37 deletions
+86
-37
bt5/erp5_wendelin/TestTemplateItem/portal_components/test.erp5.testWendelin.py
...tTemplateItem/portal_components/test.erp5.testWendelin.py
+79
-32
bt5/erp5_wendelin/TestTemplateItem/portal_components/test.erp5.testWendelin.xml
...TemplateItem/portal_components/test.erp5.testWendelin.xml
+7
-5
No files found.
bt5/erp5_wendelin/TestTemplateItem/portal_components/test.erp5.testWendelin.py
View file @
501d29e9
...
...
@@ -26,6 +26,7 @@
##############################################################################
from
Products.ERP5Type.tests.ERP5TypeTestCase
import
ERP5TypeTestCase
from
Products.ERP5Type.tests.utils
import
createZODBPythonScript
from
wendelin.bigarray.array_zodb
import
ZBigArray
from
DateTime
import
DateTime
import
msgpack
...
...
@@ -57,31 +58,13 @@ class Test(ERP5TypeTestCase):
# here, you can create the categories and objects your test will depend on
pass
def
test_0_import
(
self
):
"""
Test we can import certain libraries but still failure to do so should be a
a test step failure rather than global test failure.
"""
import
scipy
import
sklearn
import
pandas
def
test_01_IngestionFromFluentd
(
self
):
def
stepSetupIngestion
(
self
,
reference
):
"""
Test ingestion using a POST Request containing a msgpack encoded message
simulating input from fluentd
Generic step.
"""
now
=
DateTime
()
portal
=
self
.
portal
request
=
portal
.
REQUEST
reference
=
getRandomString
()
number_string_list
=
[]
for
my_list
in
list
(
chunks
(
range
(
0
,
100001
),
10
)):
number_string_list
.
append
(
','
.
join
([
str
(
x
)
for
x
in
my_list
]))
real_data
=
'
\
n
'
.
join
(
number_string_list
)
# make sure real_data tail is also a full line
real_data
+=
'
\
n
'
# create ingestion policy
ingestion_policy
=
portal
.
portal_ingestion_policies
.
newContent
(
\
...
...
@@ -116,8 +99,44 @@ class Test(ERP5TypeTestCase):
data_supply
=
ingestion_policy
.
PortalIngestionPolicy_addDataSupply
(
\
data_supply_kw
,
\
data_supply_line_kw
)
data_array
=
portal
.
data_array_module
.
newContent
(
portal_type
=
'Data Array'
,
reference
=
reference
,
version
=
'001'
)
data_array
.
validate
()
self
.
tic
()
return
ingestion_policy
,
data_supply
,
data_stream
,
data_array
def
test_0_import
(
self
):
"""
Test we can import certain libraries but still failure to do so should be a
a test step failure rather than global test failure.
"""
import
scipy
import
sklearn
import
pandas
def
test_01_IngestionFromFluentd
(
self
):
"""
Test ingestion using a POST Request containing a msgpack encoded message
simulating input from fluentd.
"""
portal
=
self
.
portal
request
=
portal
.
REQUEST
reference
=
getRandomString
()
number_string_list
=
[]
for
my_list
in
list
(
chunks
(
range
(
0
,
100001
),
10
)):
number_string_list
.
append
(
','
.
join
([
str
(
x
)
for
x
in
my_list
]))
real_data
=
'
\
n
'
.
join
(
number_string_list
)
# make sure real_data tail is also a full line
real_data
+=
'
\
n
'
ingestion_policy
,
data_supply
,
data_stream
,
data_array
=
\
self
.
stepSetupIngestion
(
reference
)
# simulate fluentd by setting proper values in REQUEST
request
.
method
=
'POST'
data_chunk
=
msgpack
.
packb
([
0
,
real_data
],
use_bin_type
=
True
)
...
...
@@ -125,19 +144,10 @@ class Test(ERP5TypeTestCase):
request
.
set
(
'data_chunk'
,
data_chunk
)
ingestion_policy
.
ingest
()
# ingestion handler script saves new data using new line so we
# need to remove it, it also stringifies thus we need to
data_stream_data
=
data_stream
.
getData
()
self
.
assertEqual
(
real_data
,
data_stream_data
)
# try sample transformation
data_array
=
portal
.
data_array_module
.
newContent
(
portal_type
=
'Data Array'
,
reference
=
reference
,
version
=
'001'
)
data_array
.
validate
()
self
.
tic
()
data_stream
.
DataStream_transform
(
\
chunk_length
=
10450
,
\
transform_script_id
=
'DataStream_copyCSVToDataArray'
,
...
...
@@ -145,13 +155,50 @@ class Test(ERP5TypeTestCase):
self
.
tic
()
# test
some numpy operations
# test
that extracted array contains same values as input CSV
zarray
=
data_array
.
getArray
()
np
.
average
(
zarray
)
self
.
assertEqual
(
np
.
average
(
zarray
),
np
.
average
(
np
.
arange
(
100001
)))
self
.
assertTrue
(
np
.
array_equal
(
zarray
,
np
.
arange
(
100001
)))
def
test_01_1_IngestionTail
(
self
):
"""
Test real time convertion to a numpy array by appending data to a data stream.
"""
portal
=
self
.
portal
reference
=
getRandomString
()
number_string_list
=
[]
for
my_list
in
list
(
chunks
(
range
(
0
,
100001
),
10
)):
number_string_list
.
append
(
','
.
join
([
str
(
x
)
for
x
in
my_list
]))
real_data
=
'
\
n
'
.
join
(
number_string_list
)
# make sure real_data tail is also a full line
real_data
+=
'
\
n
'
ingestion_policy
,
data_supply
,
data_stream
,
data_array
=
self
.
stepSetupIngestion
(
reference
)
# override DataStream_transformTail to actually do transformation on appenData
script_id
=
'DataStream_transformTail'
script_content_list
=
[
'**kw'
,
"""
# created by testWendelin.test_01_1_IngestionTail
context.DataStream_transform(
\
chunk_length = 10450,
\
transform_script_id = 'DataStream_copyCSVToDataArray',
data_array_reference = context.getReference())"""
]
createZODBPythonScript
(
portal
.
portal_skins
.
custom
,
script_id
,
*
script_content_list
)
# append data to Data Stream and check array.
data_stream
.
appendData
(
real_data
)
self
.
tic
()
# test that extracted array contains same values as input CSV
zarray
=
data_array
.
getArray
()
self
.
assertEqual
(
np
.
average
(
zarray
),
np
.
average
(
np
.
arange
(
100001
)))
self
.
assertTrue
(
np
.
array_equal
(
zarray
,
np
.
arange
(
100001
)))
# clean up script
portal
.
portal_skins
.
custom
.
manage_delObjects
([
script_id
,])
self
.
tic
()
def
test_02_Examples
(
self
):
"""
Test we can use python scientific libraries by using directly created
...
...
bt5/erp5_wendelin/TestTemplateItem/portal_components/test.erp5.testWendelin.xml
View file @
501d29e9
...
...
@@ -46,11 +46,13 @@
<key>
<string>
text_content_warning_message
</string>
</key>
<value>
<tuple>
<string>
W: 38, 8: Unused variable \'n\' (unused-variable)
</string>
<string>
W: 65, 4: Unused variable \'scipy\' (unused-variable)
</string>
<string>
W: 67, 4: Unused variable \'pandas\' (unused-variable)
</string>
<string>
W: 66, 4: Unused variable \'sklearn\' (unused-variable)
</string>
<string>
W:116, 4: Unused variable \'data_supply\' (unused-variable)
</string>
<string>
W: 39, 8: Unused variable \'n\' (unused-variable)
</string>
<string>
W:117, 4: Unused variable \'scipy\' (unused-variable)
</string>
<string>
W:119, 4: Unused variable \'pandas\' (unused-variable)
</string>
<string>
W:118, 4: Unused variable \'sklearn\' (unused-variable)
</string>
<string>
W:137, 22: Unused variable \'data_supply\' (unused-variable)
</string>
<string>
W:177, 4: Unused variable \'ingestion_policy\' (unused-variable)
</string>
<string>
W:177, 22: Unused variable \'data_supply\' (unused-variable)
</string>
</tuple>
</value>
</item>
...
...
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