2020-11-24 20:15:49 +00:00
import pytest
from ereuse_devicehub . client import UserClient
from ereuse_devicehub . resources . action import models as ma
2021-10-14 10:56:33 +00:00
from ereuse_devicehub . resources . documents import documents
2021-10-19 16:19:25 +00:00
from ereuse_devicehub . resources . lot . models import Lot
from ereuse_devicehub . resources . tradedocument . models import TradeDocument
2020-11-24 20:15:49 +00:00
from tests import conftest
2021-07-02 15:40:20 +00:00
from tests . conftest import file , yaml2json , json_encode
2020-11-24 20:15:49 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures ( conftest . app_context . __name__ )
def test_simple_metrics ( user : UserClient ) :
""" Checks one standard query of metrics """
# Insert computer
2021-07-02 15:40:20 +00:00
lenovo = yaml2json ( ' desktop-9644w8n-lenovo-0169622.snapshot ' )
acer = yaml2json ( ' acer.happy.battery.snapshot ' )
user . post ( json_encode ( lenovo ) , res = ma . Snapshot )
snapshot , _ = user . post ( json_encode ( acer ) , res = ma . Snapshot )
2020-11-24 20:15:49 +00:00
device_id = snapshot [ ' device ' ] [ ' id ' ]
2020-11-27 18:14:29 +00:00
post_request = { " transaction " : " ccc " , " name " : " John " , " endUsers " : 1 ,
2020-12-01 14:33:49 +00:00
" finalUserCode " : " abcdefjhi " ,
2020-11-24 20:15:49 +00:00
" devices " : [ device_id ] , " description " : " aaa " ,
2020-11-27 18:14:29 +00:00
" startTime " : " 2020-11-01T02:00:00+00:00 " ,
2021-10-19 16:19:25 +00:00
" endTime " : " 2020-12-01T02:00:00+00:00 " }
2020-11-24 20:15:49 +00:00
# Create Allocate
user . post ( res = ma . Allocate , data = post_request )
acer [ ' uuid ' ] = " 490fb8c0-81a1-42e9-95e0-5e7db7038ec3 "
hdd = [ c for c in acer [ ' components ' ] if c [ ' type ' ] == ' HardDrive ' ] [ 0 ]
hdd_action = [ a for a in hdd [ ' actions ' ] if a [ ' type ' ] == ' TestDataStorage ' ] [ 0 ]
hdd_action [ ' powerCycleCount ' ] + = 1000
2020-12-29 18:54:00 +00:00
acer . pop ( ' elapsed ' )
acer [ ' licence_version ' ] = ' 1.0.0 '
user . post ( acer , res = ma . Live )
2020-11-24 20:15:49 +00:00
# Create a live
acer [ ' uuid ' ] = " 490fb8c0-81a1-42e9-95e0-5e7db7038ec4 "
hdd = [ c for c in acer [ ' components ' ] if c [ ' type ' ] == ' HardDrive ' ] [ 0 ]
hdd_action = [ a for a in hdd [ ' actions ' ] if a [ ' type ' ] == ' TestDataStorage ' ] [ 0 ]
hdd_action [ ' powerCycleCount ' ] + = 1000
2020-12-29 18:54:00 +00:00
user . post ( acer , res = ma . Live )
2020-11-24 20:15:49 +00:00
# Create an other live
acer [ ' uuid ' ] = " 490fb8c0-81a1-42e9-95e0-5e7db7038ec5 "
hdd = [ c for c in acer [ ' components ' ] if c [ ' type ' ] == ' HardDrive ' ] [ 0 ]
hdd_action = [ a for a in hdd [ ' actions ' ] if a [ ' type ' ] == ' TestDataStorage ' ] [ 0 ]
hdd_action [ ' powerCycleCount ' ] + = 1000
2020-12-29 18:54:00 +00:00
user . post ( acer , res = ma . Live )
2020-11-24 20:15:49 +00:00
# Check metrics
2020-11-25 12:58:32 +00:00
metrics = { ' allocateds ' : 1 , ' live ' : 1 }
2020-11-25 14:55:47 +00:00
res , _ = user . get ( " /metrics/ " )
2020-11-24 20:15:49 +00:00
assert res == metrics
@pytest.mark.mvp
@pytest.mark.usefixtures ( conftest . app_context . __name__ )
def test_second_hdd_metrics ( user : UserClient ) :
""" Checks one standard query of metrics """
# Insert computer
2021-07-02 15:40:20 +00:00
acer = yaml2json ( ' acer.happy.battery.snapshot ' )
snapshot , _ = user . post ( json_encode ( acer ) , res = ma . Snapshot )
2020-11-24 20:15:49 +00:00
device_id = snapshot [ ' device ' ] [ ' id ' ]
2020-11-27 18:14:29 +00:00
post_request = { " transaction " : " ccc " , " name " : " John " , " endUsers " : 1 ,
2020-12-01 14:33:49 +00:00
" finalUserCode " : " abcdefjhi " ,
2020-11-24 20:15:49 +00:00
" devices " : [ device_id ] , " description " : " aaa " ,
2020-11-27 18:14:29 +00:00
" startTime " : " 2020-11-01T02:00:00+00:00 " ,
2021-10-19 16:19:25 +00:00
" endTime " : " 2020-12-01T02:00:00+00:00 " }
2020-11-24 20:15:49 +00:00
# Create Allocate
user . post ( res = ma . Allocate , data = post_request )
acer [ ' uuid ' ] = " 490fb8c0-81a1-42e9-95e0-5e7db7038ec3 "
hdd = [ c for c in acer [ ' components ' ] if c [ ' type ' ] == ' HardDrive ' ] [ 0 ]
hdd_action = [ a for a in hdd [ ' actions ' ] if a [ ' type ' ] == ' TestDataStorage ' ] [ 0 ]
hdd_action [ ' powerCycleCount ' ] + = 1000
2020-12-29 18:54:00 +00:00
acer . pop ( ' elapsed ' )
acer [ ' licence_version ' ] = ' 1.0.0 '
user . post ( acer , res = ma . Live )
2020-11-24 20:15:49 +00:00
# Create a live
acer [ ' uuid ' ] = " 490fb8c0-81a1-42e9-95e0-5e7db7038ec4 "
hdd = [ c for c in acer [ ' components ' ] if c [ ' type ' ] == ' HardDrive ' ] [ 0 ]
hdd_action = [ a for a in hdd [ ' actions ' ] if a [ ' type ' ] == ' TestDataStorage ' ] [ 0 ]
hdd_action [ ' powerCycleCount ' ] + = 1000
2020-12-29 18:54:00 +00:00
user . post ( acer , res = ma . Live )
2020-11-24 20:15:49 +00:00
# Create a second device
acer [ ' uuid ' ] = " 490fb8c0-81a1-42e9-95e0-5e7db7038ec5 "
hdd = [ c for c in acer [ ' components ' ] if c [ ' type ' ] == ' HardDrive ' ] [ 0 ]
hdd [ ' serialNumber ' ] = ' WD-WX11A80W7440 '
2020-12-29 18:54:00 +00:00
user . post ( acer , res = ma . Live )
2020-11-24 20:15:49 +00:00
2020-11-25 14:55:47 +00:00
# Check metrics if we change the hdd we need a result of one device
metrics = { ' allocateds ' : 1 , ' live ' : 1 }
res , _ = user . get ( " /metrics/ " )
2020-11-24 20:15:49 +00:00
assert res == metrics
2020-11-25 16:46:58 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures ( conftest . app_context . __name__ )
def test_metrics_with_live_null ( user : UserClient ) :
""" Checks one standard query of metrics """
# Insert computer
acer = file ( ' acer.happy.battery.snapshot ' )
snapshot , _ = user . post ( acer , res = ma . Snapshot )
device_id = snapshot [ ' device ' ] [ ' id ' ]
2020-11-27 18:14:29 +00:00
post_request = { " transaction " : " ccc " , " name " : " John " , " endUsers " : 1 ,
2020-12-01 14:33:49 +00:00
" finalUserCode " : " abcdefjhi " ,
2020-11-25 16:46:58 +00:00
" devices " : [ device_id ] , " description " : " aaa " ,
2020-11-27 18:14:29 +00:00
" startTime " : " 2020-11-01T02:00:00+00:00 " ,
2021-10-19 16:19:25 +00:00
" endTime " : " 2020-12-01T02:00:00+00:00 " }
2020-11-25 16:46:58 +00:00
# Create Allocate
user . post ( res = ma . Allocate , data = post_request )
# Check metrics if we change the hdd we need a result of one device
metrics = { ' allocateds ' : 1 , ' live ' : 0 }
res , _ = user . get ( " /metrics/ " )
assert res == metrics
2021-10-14 10:56:33 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures ( conftest . app_context . __name__ )
def test_metrics_action_status ( user : UserClient , user2 : UserClient ) :
2021-10-19 16:19:25 +00:00
""" Checks one standard query of metrics. """
2021-10-14 10:56:33 +00:00
# Insert computer
lenovo = yaml2json ( ' desktop-9644w8n-lenovo-0169622.snapshot ' )
snap , _ = user . post ( json_encode ( lenovo ) , res = ma . Snapshot )
2021-12-09 09:59:26 +00:00
device_id = snap [ ' device ' ] [ ' id ' ]
action = { ' type ' : ma . Use . t , ' devices ' : [ device_id ] }
2021-10-14 10:56:33 +00:00
action_use , _ = user . post ( action , res = ma . Action )
csv_str , _ = user . get ( res = documents . DocumentDef . t ,
item = ' actions/ ' ,
accept = ' text/csv ' ,
2021-12-09 09:59:26 +00:00
query = [ ( ' filter ' , { ' type ' : [ ' Computer ' ] , ' ids ' : [ device_id ] } ) ] )
2021-11-04 10:58:15 +00:00
head = ' DHID;Hid;Document-Name;Action-Type;Action-User-LastOwner-Supplier;Action-User-LastOwner-Receiver;Action-Create-By;Trade-Confirmed;Status-Created-By-Supplier-About-Reciber;Status-Receiver;Status Supplier – Created Date;Status Receiver – Created Date;Trade-Weight;Action-Create;Allocate-Start;Allocate-User-Code;Allocate-NumUsers;UsageTimeAllocate;Type;LiveCreate;UsageTimeHdd \n '
2021-10-23 11:02:10 +00:00
body = ' O48N2;desktop-lenovo-9644w8n-0169622-00:1a:6b:5e:7f:10;;Status;;foo@foo.com;Receiver;;;Use;; '
2021-10-14 16:13:20 +00:00
assert head in csv_str
assert body in csv_str
2021-10-14 10:56:33 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures ( conftest . app_context . __name__ )
2021-10-19 16:19:25 +00:00
def test_complet_metrics_with_trade ( user : UserClient , user2 : UserClient ) :
""" Checks one standard query of metrics in a trade enviroment. """
2021-10-14 10:56:33 +00:00
# Insert computer
lenovo = yaml2json ( ' desktop-9644w8n-lenovo-0169622.snapshot ' )
acer = yaml2json ( ' acer.happy.battery.snapshot ' )
snap1 , _ = user . post ( json_encode ( lenovo ) , res = ma . Snapshot )
snap2 , _ = user . post ( json_encode ( acer ) , res = ma . Snapshot )
lot , _ = user . post ( { ' name ' : ' MyLot ' } , res = Lot )
2021-12-09 09:59:26 +00:00
device1_id = snap1 [ ' device ' ] [ ' id ' ]
device2_id = snap2 [ ' device ' ] [ ' id ' ]
devices_id = [ device1_id , device2_id ]
devices = [ ( ' id ' , device1_id ) ,
2021-10-19 16:19:25 +00:00
( ' id ' , snap2 [ ' device ' ] [ ' id ' ] ) ]
2021-10-14 10:56:33 +00:00
lot , _ = user . post ( { } ,
res = Lot ,
item = ' {} /devices ' . format ( lot [ ' id ' ] ) ,
query = devices )
2021-11-02 11:47:23 +00:00
2021-12-09 09:59:26 +00:00
action = { ' type ' : ma . Refurbish . t , ' devices ' : [ device1_id ] }
2021-11-02 11:47:23 +00:00
user . post ( action , res = ma . Action )
2021-10-19 16:19:25 +00:00
request_post = {
' type ' : ' Trade ' ,
2021-12-09 09:59:26 +00:00
' devices ' : devices_id ,
2021-10-19 16:19:25 +00:00
' userFromEmail ' : user . email ,
' userToEmail ' : user2 . email ,
' price ' : 10 ,
' date ' : " 2020-12-01T02:00:00+00:00 " ,
' lot ' : lot [ ' id ' ] ,
' confirms ' : True ,
}
user . post ( res = ma . Action , data = request_post )
2021-12-09 09:59:26 +00:00
action = { ' type ' : ma . Use . t , ' devices ' : [ device1_id ] }
2021-10-19 16:19:25 +00:00
action_use , _ = user . post ( action , res = ma . Action )
csv_str , _ = user . get ( res = documents . DocumentDef . t ,
item = ' actions/ ' ,
accept = ' text/csv ' ,
2021-12-09 09:59:26 +00:00
query = [ ( ' filter ' , { ' type ' : [ ' Computer ' ] , ' ids ' : devices_id } ) ] )
2021-10-19 16:19:25 +00:00
2021-11-02 11:47:23 +00:00
body1_lenovo = ' O48N2;desktop-lenovo-9644w8n-0169622-00:1a:6b:5e:7f:10;;Trade;foo@foo.com; '
2021-11-11 21:08:28 +00:00
body1_lenovo + = ' foo2@foo.com;Supplier;NeedConfirmation;Use;; '
2021-10-19 16:19:25 +00:00
body2_lenovo = ' ;;0;0;Trade;0;0 \n '
2021-11-02 11:47:23 +00:00
body1_acer = ' J2MA2;laptop-acer-aohappy-lusea0d010038879a01601-00:26:c7:8e:cb:8c;;Trade; '
2021-11-11 21:08:28 +00:00
body1_acer + = ' foo@foo.com;foo2@foo.com;Supplier;NeedConfirmation;;;;;0; '
2021-10-19 16:19:25 +00:00
body2_acer = ' ;;0;0;Trade;0;4692.0 \n '
assert body1_lenovo in csv_str
assert body2_lenovo in csv_str
assert body1_acer in csv_str
assert body2_acer in csv_str
# User2 mark this device as Refurbish
2021-12-09 09:59:26 +00:00
action = { ' type ' : ma . Use . t , ' devices ' : [ device1_id ] }
2021-10-19 16:19:25 +00:00
action_use2 , _ = user2 . post ( action , res = ma . Action )
csv_str , _ = user . get ( res = documents . DocumentDef . t ,
item = ' actions/ ' ,
accept = ' text/csv ' ,
2021-12-09 09:59:26 +00:00
query = [ ( ' filter ' , { ' type ' : [ ' Computer ' ] , ' ids ' : devices_id } ) ] )
2021-10-19 16:19:25 +00:00
2021-11-03 09:37:15 +00:00
body1_lenovo = ' O48N2;desktop-lenovo-9644w8n-0169622-00:1a:6b:5e:7f:10;;Trade;foo@foo.com; '
2021-11-11 21:08:28 +00:00
body1_lenovo + = ' foo2@foo.com;Supplier;NeedConfirmation;Use;Use; '
2021-11-03 09:37:15 +00:00
body2_lenovo = ' ;;0;0;Trade;0;0 \n '
body2_acer = ' ;;0;0;Trade;0;4692.0 \n '
assert body1_lenovo in csv_str
assert body2_lenovo in csv_str
assert body2_acer in csv_str
2021-10-19 16:19:25 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures ( conftest . app_context . __name__ )
def test_metrics_action_status_for_containers ( user : UserClient , user2 : UserClient ) :
""" Checks one standard query of metrics for a container. """
# Insert computer
lenovo = yaml2json ( ' desktop-9644w8n-lenovo-0169622.snapshot ' )
snap , _ = user . post ( json_encode ( lenovo ) , res = ma . Snapshot )
lot , _ = user . post ( { ' name ' : ' MyLot ' } , res = Lot )
devices = [ ( ' id ' , snap [ ' device ' ] [ ' id ' ] ) ]
lot , _ = user . post ( { } ,
res = Lot ,
item = ' {} /devices ' . format ( lot [ ' id ' ] ) ,
query = devices )
request_post = {
' type ' : ' Trade ' ,
' devices ' : [ snap [ ' device ' ] [ ' id ' ] ] ,
' userFromEmail ' : user . email ,
' userToEmail ' : user2 . email ,
' price ' : 10 ,
' date ' : " 2020-12-01T02:00:00+00:00 " ,
' lot ' : lot [ ' id ' ] ,
' confirms ' : True ,
}
user . post ( res = ma . Action , data = request_post )
request_post = {
' filename ' : ' test.pdf ' ,
' hash ' : ' bbbbbbbb ' ,
' url ' : ' http://www.ereuse.org/ ' ,
' weight ' : 150 ,
' lot ' : lot [ ' id ' ]
}
tradedocument , _ = user . post ( res = TradeDocument , data = request_post )
action = { ' type ' : ma . Recycling . t , ' devices ' : [ ] , ' documents ' : [ tradedocument [ ' id ' ] ] }
action , _ = user . post ( action , res = ma . Action )
trade = TradeDocument . query . one ( )
assert str ( trade . actions [ - 1 ] . id ) == action [ ' id ' ]
2021-12-09 09:59:26 +00:00
# get metrics from botom in lot menu
2021-10-19 16:19:25 +00:00
csv_str , _ = user . get ( res = documents . DocumentDef . t ,
item = ' actions/ ' ,
accept = ' text/csv ' ,
2021-12-09 09:59:26 +00:00
query = [ ( ' filter ' , { ' type ' : [ ' Computer ' ] } ) , ( ' lot ' , lot [ ' id ' ] ) ] )
2021-10-19 16:19:25 +00:00
2021-11-23 10:26:21 +00:00
body1 = ' ;bbbbbbbb;test.pdf;Trade-Container;foo@foo.com;foo2@foo.com;Supplier;False;Recycling;; '
body2 = ' ;;150.0; '
body3 = ' ;;0;0;Trade-Container;0;0 '
2021-12-09 09:59:26 +00:00
assert len ( csv_str . split ( ' \n ' ) ) == 3
2021-10-20 12:53:33 +00:00
assert body1 in csv_str . split ( ' \n ' ) [ - 2 ]
assert body2 in csv_str . split ( ' \n ' ) [ - 2 ]
2021-11-23 10:26:21 +00:00
assert body3 in csv_str . split ( ' \n ' ) [ - 2 ]
2021-10-20 12:53:33 +00:00
2021-12-09 09:59:26 +00:00
# get metrics from botom in devices menu
csv_str2 , _ = user . get ( res = documents . DocumentDef . t ,
item = ' actions/ ' ,
accept = ' text/csv ' ,
query = [ ( ' filter ' , { ' type ' : [ ' Computer ' ] , ' ids ' : [ snap [ ' device ' ] [ ' id ' ] ] } ) ] )
assert len ( csv_str2 . split ( ' \n ' ) ) == 4
assert body1 in csv_str2 . split ( ' \n ' ) [ - 2 ]
assert body2 in csv_str2 . split ( ' \n ' ) [ - 2 ]
assert body3 in csv_str2 . split ( ' \n ' ) [ - 2 ]
2021-10-20 12:53:33 +00:00
@pytest.mark.mvp
@pytest.mark.usefixtures ( conftest . app_context . __name__ )
def test_visual_metrics_for_old_owners ( user : UserClient , user2 : UserClient ) :
""" Checks if one old owner can see the metrics in a trade enviroment. """
# Insert computer
lenovo = yaml2json ( ' desktop-9644w8n-lenovo-0169622.snapshot ' )
snap1 , _ = user . post ( json_encode ( lenovo ) , res = ma . Snapshot )
lot , _ = user . post ( { ' name ' : ' MyLot ' } , res = Lot )
2021-12-09 09:59:26 +00:00
device_id = snap1 [ ' device ' ] [ ' id ' ]
devices = [ ( ' id ' , device_id ) ]
2021-10-20 12:53:33 +00:00
lot , _ = user . post ( { } ,
res = Lot ,
item = ' {} /devices ' . format ( lot [ ' id ' ] ) ,
query = devices )
request_post = {
' type ' : ' Trade ' ,
2021-12-09 09:59:26 +00:00
' devices ' : [ device_id ] ,
2021-10-20 12:53:33 +00:00
' userFromEmail ' : user . email ,
' userToEmail ' : user2 . email ,
' price ' : 10 ,
' date ' : " 2020-12-01T02:00:00+00:00 " ,
' lot ' : lot [ ' id ' ] ,
' confirms ' : True ,
}
trade , _ = user . post ( res = ma . Action , data = request_post )
request_confirm = {
' type ' : ' Confirm ' ,
' action ' : trade [ ' id ' ] ,
2021-12-09 09:59:26 +00:00
' devices ' : [ device_id ]
2021-10-20 12:53:33 +00:00
}
user2 . post ( res = ma . Action , data = request_confirm )
2021-12-09 09:59:26 +00:00
action = { ' type ' : ma . Refurbish . t , ' devices ' : [ device_id ] }
2021-10-20 12:53:33 +00:00
action_use , _ = user . post ( action , res = ma . Action )
csv_supplier , _ = user . get ( res = documents . DocumentDef . t ,
item = ' actions/ ' ,
accept = ' text/csv ' ,
2021-12-09 09:59:26 +00:00
query = [ ( ' filter ' , { ' type ' : [ ' Computer ' ] , ' ids ' : [ device_id ] } ) ] )
2021-10-20 12:53:33 +00:00
csv_receiver , _ = user2 . get ( res = documents . DocumentDef . t ,
item = ' actions/ ' ,
accept = ' text/csv ' ,
2021-12-09 09:59:26 +00:00
query = [ ( ' filter ' , { ' type ' : [ ' Computer ' ] , ' ids ' : [ device_id ] } ) ] )
2021-10-20 12:53:33 +00:00
body = ' ;;0;0;Trade;0;0 \n '
assert body in csv_receiver
assert body in csv_supplier
2021-10-25 08:43:28 +00:00
assert csv_receiver == csv_supplier
@pytest.mark.mvp
@pytest.mark.usefixtures ( conftest . app_context . __name__ )
def test_bug_trade_confirmed ( user : UserClient , user2 : UserClient ) :
""" When the receiber do a Trade, then the confirmation is wrong. """
lenovo = yaml2json ( ' desktop-9644w8n-lenovo-0169622.snapshot ' )
snap1 , _ = user . post ( json_encode ( lenovo ) , res = ma . Snapshot )
lot , _ = user . post ( { ' name ' : ' MyLot ' } , res = Lot )
2021-12-09 09:59:26 +00:00
device_id = snap1 [ ' device ' ] [ ' id ' ]
devices = [ ( ' id ' , device_id ) ]
2021-10-25 08:43:28 +00:00
lot , _ = user . post ( { } ,
res = Lot ,
item = ' {} /devices ' . format ( lot [ ' id ' ] ) ,
query = devices )
request_post = {
' type ' : ' Trade ' ,
2021-12-09 09:59:26 +00:00
' devices ' : [ device_id ] ,
2021-10-25 08:43:28 +00:00
' userFromEmail ' : user2 . email ,
' userToEmail ' : user . email ,
' price ' : 10 ,
' date ' : " 2020-12-01T02:00:00+00:00 " ,
' lot ' : lot [ ' id ' ] ,
' confirms ' : True ,
}
trade , _ = user . post ( res = ma . Action , data = request_post )
csv_not_confirmed , _ = user . get ( res = documents . DocumentDef . t ,
item = ' actions/ ' ,
accept = ' text/csv ' ,
2021-12-09 09:59:26 +00:00
query = [ ( ' filter ' , { ' type ' : [ ' Computer ' ] , ' ids ' : [ device_id ] } ) ] )
2021-10-25 08:43:28 +00:00
request_confirm = {
' type ' : ' Confirm ' ,
' action ' : trade [ ' id ' ] ,
2021-12-09 09:59:26 +00:00
' devices ' : [ device_id ]
2021-10-25 08:43:28 +00:00
}
user2 . post ( res = ma . Action , data = request_confirm )
csv_confirmed , _ = user2 . get ( res = documents . DocumentDef . t ,
item = ' actions/ ' ,
accept = ' text/csv ' ,
2021-12-09 09:59:26 +00:00
query = [ ( ' filter ' , { ' type ' : [ ' Computer ' ] , ' ids ' : [ device_id ] } ) ] )
2021-10-25 08:43:28 +00:00
2021-11-11 21:08:28 +00:00
body_not_confirmed = " Trade;foo2@foo.com;foo@foo.com;Receiver;NeedConfirmation; "
body_confirmed = " Trade;foo2@foo.com;foo@foo.com;Receiver;TradeConfirmed; "
2021-10-25 08:43:28 +00:00
assert body_not_confirmed in csv_not_confirmed
assert body_confirmed in csv_confirmed