Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.core
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
1
Merge Requests
1
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
Romain Courteaud
slapos.core
Commits
f77ba5b7
Commit
f77ba5b7
authored
Jan 27, 2023
by
Romain Courteaud
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
slapos_cloud: test compute network sla
parent
e06e8e55
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
120 additions
and
102 deletions
+120
-102
master/bt5/slapos_cloud/TestTemplateItem/portal_components/test.erp5.testSlapOSCloudAllocationAlarm.py
...al_components/test.erp5.testSlapOSCloudAllocationAlarm.py
+120
-102
No files found.
master/bt5/slapos_cloud/TestTemplateItem/portal_components/test.erp5.testSlapOSCloudAllocationAlarm.py
View file @
f77ba5b7
...
@@ -6,8 +6,23 @@ from unittest import skip
...
@@ -6,8 +6,23 @@ from unittest import skip
class
TestSlapOSAllocation
(
SlapOSTestCaseMixin
):
class
TestSlapOSAllocation
(
SlapOSTestCaseMixin
):
def
makeAllocableSoftwareInstance
(
self
,
allocation_state
=
'possible'
,
shared
=
False
,
node
=
"compute"
):
def
makeAllocableComputeNode
(
self
,
project
,
software_product
,
software_product
,
release_variation
,
type_variation
,
compute_node
,
partition
,
instance_tree
=
self
.
bootstrapAllocableInstanceTree
(
allocation_state
=
allocation_state
,
shared
=
shared
,
node
=
node
)
release_variation
,
type_variation
):
compute_node
,
partition
=
self
.
_makeComputeNode
(
project
)
self
.
addAllocationSupply
(
"for compute node"
,
compute_node
,
software_product
,
release_variation
,
type_variation
)
self
.
_installSoftware
(
compute_node
,
release_variation
.
getUrlString
()
)
self
.
tic
()
return
compute_node
,
partition
def
makeAllocableSoftwareInstanceAndProduct
(
self
,
allocation_state
=
'possible'
,
shared
=
False
,
node
=
"compute"
):
software_product
,
release_variation
,
type_variation
,
compute_node
,
partition
,
instance_tree
=
\
self
.
bootstrapAllocableInstanceTree
(
allocation_state
=
allocation_state
,
shared
=
shared
,
node
=
node
)
self
.
addAllocationSupply
(
"for compute node"
,
compute_node
,
software_product
,
self
.
addAllocationSupply
(
"for compute node"
,
compute_node
,
software_product
,
release_variation
,
type_variation
)
release_variation
,
type_variation
)
real_compute_node
=
partition
.
getParentValue
()
real_compute_node
=
partition
.
getParentValue
()
...
@@ -22,6 +37,11 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -22,6 +37,11 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
software_instance
=
instance_tree
.
getSuccessorValue
()
software_instance
=
instance_tree
.
getSuccessorValue
()
return
software_instance
,
compute_node
,
partition
,
software_product
,
release_variation
,
type_variation
def
makeAllocableSoftwareInstance
(
self
,
allocation_state
=
'possible'
,
shared
=
False
,
node
=
"compute"
):
software_instance
,
compute_node
,
partition
,
_
,
_
,
_
=
\
self
.
makeAllocableSoftwareInstanceAndProduct
(
allocation_state
=
allocation_state
,
shared
=
shared
,
node
=
node
)
return
software_instance
,
compute_node
,
partition
return
software_instance
,
compute_node
,
partition
def
_installSoftware
(
self
,
compute_node
,
url
):
def
_installSoftware
(
self
,
compute_node
,
url
):
...
@@ -291,40 +311,41 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -291,40 +311,41 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
@
simulate
(
'Person_isAllowedToAllocate'
,
'*args, **kwargs'
,
'return True'
)
@
simulate
(
'Person_isAllowedToAllocate'
,
'*args, **kwargs'
,
'return True'
)
def
test_allocation_network_guid
(
self
):
def
test_allocation_network_guid
(
self
):
s
elf
.
_makeTree
(
self
.
project
)
s
oftware_instance
,
compute_node
,
partition
=
self
.
makeAllocableSoftwareInstance
(
)
self
.
_makeComputeNode
(
self
.
project
)
new_id
=
self
.
generateNewId
()
new_id
=
self
.
generateNewId
()
computer_network
=
self
.
portal
.
computer_network_module
.
newContent
(
computer_network
=
self
.
portal
.
computer_network_module
.
newContent
(
portal_type
=
'Computer Network'
,
portal_type
=
'Computer Network'
,
title
=
"live_test_%s"
%
new_id
,
title
=
"live_test_%s"
%
new_id
,
reference
=
"live_test_%s"
%
new_id
)
reference
=
"live_test_%s"
%
new_id
,
follow_up_value
=
software_instance
.
getFollowUpValue
()
)
computer_network
.
validate
()
computer_network
.
validate
()
self
.
compute_node
.
edit
(
compute_node
.
edit
(
subordination_value
=
computer_network
)
subordination_value
=
computer_network
self
.
_installSoftware
(
self
.
compute_node
,
)
self
.
software_instance
.
getUrlString
()
)
self
.
tic
(
)
self
.
assertEqual
(
None
,
s
elf
.
s
oftware_instance
.
getAggregateValue
(
self
.
assertEqual
(
None
,
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
portal_type
=
'Compute Partition'
))
s
elf
.
s
oftware_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
software_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
<instance>
<instance>
<parameter id='network_guid'>%s</parameter>
<parameter id='network_guid'>%s</parameter>
</instance>"""
%
'%s_foo'
%
\
</instance>"""
%
'%s_foo'
%
\
self
.
partition
.
getParentValue
().
getSubordinationReference
())
partition
.
getParentValue
().
getSubordinationReference
())
s
elf
.
s
oftware_instance
.
SoftwareInstance_tryToAllocatePartition
()
software_instance
.
SoftwareInstance_tryToAllocatePartition
()
self
.
assertEqual
(
None
,
self
.
assertEqual
(
None
,
s
elf
.
s
oftware_instance
.
getAggregate
(
portal_type
=
'Compute Partition'
))
software_instance
.
getAggregate
(
portal_type
=
'Compute Partition'
))
s
elf
.
s
oftware_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
software_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
<instance>
<instance>
<parameter id='network_guid'>%s</parameter>
<parameter id='network_guid'>%s</parameter>
</instance>"""
%
'%s'
%
\
</instance>"""
%
'%s'
%
\
self
.
partition
.
getParentValue
().
getSubordinationReference
())
partition
.
getParentValue
().
getSubordinationReference
())
s
elf
.
s
oftware_instance
.
SoftwareInstance_tryToAllocatePartition
()
software_instance
.
SoftwareInstance_tryToAllocatePartition
()
self
.
assertEqual
(
self
.
partition
.
getRelativeUrl
(),
self
.
assertEqual
(
partition
.
getRelativeUrl
(),
s
elf
.
s
oftware_instance
.
getAggregate
(
portal_type
=
'Compute Partition'
))
software_instance
.
getAggregate
(
portal_type
=
'Compute Partition'
))
@
simulate
(
'Person_isAllowedToAllocate'
,
'*args, **kwargs'
,
'return True'
)
@
simulate
(
'Person_isAllowedToAllocate'
,
'*args, **kwargs'
,
'return True'
)
def
test_allocation_mode_unique_by_network_one_network
(
self
):
def
test_allocation_mode_unique_by_network_one_network
(
self
):
...
@@ -340,11 +361,13 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -340,11 +361,13 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
<instance>
<instance>
<parameter id='mode'>unique_by_network</parameter>
<parameter id='mode'>unique_by_network</parameter>
</instance>"""
</instance>"""
self
.
_makeTree
(
self
.
project
)
software_instance
,
compute_node1
,
_
,
software_product
,
release_variation
,
type_variation
=
\
compute_node1
=
self
.
_makeComputeNode
(
self
.
project
)[
0
]
self
.
makeAllocableSoftwareInstanceAndProduct
()
compute_node2
=
self
.
_makeComputeNode
(
self
.
project
)[
0
]
self
.
_installSoftware
(
compute_node1
,
self
.
software_instance
.
getUrlString
())
instance_tree
=
software_instance
.
getSpecialiseValue
()
self
.
_installSoftware
(
compute_node2
,
self
.
software_instance
.
getUrlString
())
project
=
compute_node1
.
getFollowUpValue
()
compute_node2
,
_
=
self
.
makeAllocableComputeNode
(
project
,
software_product
,
release_variation
,
type_variation
)
new_id
=
self
.
generateNewId
()
new_id
=
self
.
generateNewId
()
computer_network
=
self
.
portal
.
computer_network_module
.
newContent
(
computer_network
=
self
.
portal
.
computer_network_module
.
newContent
(
...
@@ -355,7 +378,7 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -355,7 +378,7 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
compute_node1
.
edit
(
subordination_value
=
computer_network
)
compute_node1
.
edit
(
subordination_value
=
computer_network
)
compute_node2
.
edit
(
subordination_value
=
computer_network
)
compute_node2
.
edit
(
subordination_value
=
computer_network
)
self
.
assertEqual
(
None
,
s
elf
.
s
oftware_instance
.
getAggregateValue
(
self
.
assertEqual
(
None
,
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
portal_type
=
'Compute Partition'
))
software_instance2
=
self
.
portal
.
software_instance_module
\
software_instance2
=
self
.
portal
.
software_instance_module
\
...
@@ -363,37 +386,37 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -363,37 +386,37 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
software_instance2
.
edit
(
software_instance2
.
edit
(
title
=
self
.
generateNewSoftwareTitle
(),
title
=
self
.
generateNewSoftwareTitle
(),
reference
=
"TESTSI-%s"
%
self
.
generateNewId
(),
reference
=
"TESTSI-%s"
%
self
.
generateNewId
(),
url_string
=
s
elf
.
s
oftware_instance
.
getUrlString
(),
url_string
=
software_instance
.
getUrlString
(),
source_reference
=
s
elf
.
generateNewSoftwareTyp
e
(),
source_reference
=
s
oftware_instance
.
getSourceReferenc
e
(),
text_content
=
self
.
generateSafeXml
(),
text_content
=
self
.
generateSafeXml
(),
sla_xml
=
sla_xml
,
sla_xml
=
sla_xml
,
specialise
=
self
.
instance_tree
.
getRelativeUrl
()
,
specialise
_value
=
instance_tree
,
follow_up_value
=
self
.
project
follow_up_value
=
project
)
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'start_requested'
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'start_requested'
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'validated'
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'validated'
)
self
.
tic
()
self
.
tic
()
self
.
assertEqual
(
None
,
self
.
assertEqual
(
None
,
s
elf
.
s
oftware_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
self
.
assertEqual
(
s
elf
.
s
oftware_instance
.
getSlapState
(),
'start_requested'
)
self
.
assertEqual
(
software_instance
.
getSlapState
(),
'start_requested'
)
self
.
assertEqual
(
s
elf
.
s
oftware_instance
.
getValidationState
(),
'validated'
)
self
.
assertEqual
(
software_instance
.
getValidationState
(),
'validated'
)
s
elf
.
s
oftware_instance
.
setSlaXml
(
sla_xml
)
software_instance
.
setSlaXml
(
sla_xml
)
s
elf
.
s
oftware_instance
.
SoftwareInstance_tryToAllocatePartition
()
software_instance
.
SoftwareInstance_tryToAllocatePartition
()
self
.
tic
()
self
.
tic
()
portal_workflow
=
s
elf
.
s
oftware_instance
.
portal_workflow
portal_workflow
=
software_instance
.
portal_workflow
last_workflow_item
=
portal_workflow
.
getInfoFor
(
ob
=
s
elf
.
s
oftware_instance
,
last_workflow_item
=
portal_workflow
.
getInfoFor
(
ob
=
software_instance
,
name
=
'comment'
,
wf_id
=
'edit_workflow'
)
name
=
'comment'
,
wf_id
=
'edit_workflow'
)
self
.
assertEqual
(
None
,
last_workflow_item
)
self
.
assertEqual
(
None
,
last_workflow_item
)
self
.
assertNotEqual
(
None
,
self
.
assertNotEqual
(
None
,
s
elf
.
s
oftware_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
self
.
assertEqual
(
self
.
assertEqual
(
computer_network
.
getReference
(),
computer_network
.
getReference
(),
s
elf
.
s
oftware_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
)
\
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
)
\
.
getParentValue
().
getSubordinationReference
(),
.
getParentValue
().
getSubordinationReference
(),
)
)
...
@@ -415,15 +438,19 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -415,15 +438,19 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
instance tree.
instance tree.
Test with 3 instances and 3 existing compute_nodes on 2 different networks.
Test with 3 instances and 3 existing compute_nodes on 2 different networks.
"""
"""
self
.
tic
()
sla_xml
=
"""<?xml version='1.0' encoding='utf-8'?>
sla_xml
=
"""<?xml version='1.0' encoding='utf-8'?>
<instance>
<instance>
<parameter id='mode'>unique_by_network</parameter>
<parameter id='mode'>unique_by_network</parameter>
</instance>"""
</instance>"""
self
.
_makeTree
(
self
.
project
)
software_instance
,
compute_node1
,
partition1
,
software_product
,
release_variation
,
type_variation
=
\
compute_node1
,
partition1
=
self
.
_makeComputeNode
(
self
.
project
)
self
.
makeAllocableSoftwareInstanceAndProduct
()
compute_node2
=
self
.
_makeComputeNode
(
self
.
project
)[
0
]
compute_node3
,
partition3
=
self
.
_makeComputeNode
(
self
.
project
)
instance_tree
=
software_instance
.
getSpecialiseValue
()
project
=
compute_node1
.
getFollowUpValue
()
compute_node2
,
_
=
self
.
makeAllocableComputeNode
(
project
,
software_product
,
release_variation
,
type_variation
)
compute_node3
,
partition3
=
self
.
makeAllocableComputeNode
(
project
,
software_product
,
release_variation
,
type_variation
)
computer_network1
=
self
.
_makeComputerNetwork
()
computer_network1
=
self
.
_makeComputerNetwork
()
computer_network2
=
self
.
_makeComputerNetwork
()
computer_network2
=
self
.
_makeComputerNetwork
()
...
@@ -431,25 +458,19 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -431,25 +458,19 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
compute_node2
.
edit
(
subordination_value
=
computer_network1
)
compute_node2
.
edit
(
subordination_value
=
computer_network1
)
compute_node3
.
edit
(
subordination_value
=
computer_network2
)
compute_node3
.
edit
(
subordination_value
=
computer_network2
)
self
.
_installSoftware
(
compute_node1
,
self
.
software_instance
.
getUrlString
())
self
.
tic
()
self
.
_installSoftware
(
compute_node2
,
self
.
software_instance
.
getUrlString
())
self
.
_installSoftware
(
compute_node3
,
self
.
software_instance
.
getUrlString
())
self
.
assertEqual
(
None
,
self
.
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
self
.
assertEqual
(
None
,
s
elf
.
requested_s
oftware_instance
.
getAggregateValue
(
self
.
assertEqual
(
None
,
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
portal_type
=
'Compute Partition'
))
software_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
self
.
software_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
<instance>
<instance>
<parameter id='mode'>unique_by_network</parameter>
<parameter id='mode'>unique_by_network</parameter>
<parameter id='computer_guid'>%s</parameter>
<parameter id='computer_guid'>%s</parameter>
</instance>"""
%
compute_node1
.
getReference
())
</instance>"""
%
compute_node1
.
getReference
())
s
elf
.
s
oftware_instance
.
SoftwareInstance_tryToAllocatePartition
()
software_instance
.
SoftwareInstance_tryToAllocatePartition
()
self
.
assertEqual
(
self
.
assertEqual
(
s
elf
.
s
oftware_instance
.
getAggregate
(
portal_type
=
'Compute Partition'
),
software_instance
.
getAggregate
(
portal_type
=
'Compute Partition'
),
partition1
.
getRelativeUrl
(),
partition1
.
getRelativeUrl
(),
)
)
...
@@ -458,16 +479,16 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -458,16 +479,16 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
software_instance2
.
edit
(
software_instance2
.
edit
(
title
=
self
.
generateNewSoftwareTitle
(),
title
=
self
.
generateNewSoftwareTitle
(),
reference
=
"TESTSI-%s"
%
self
.
generateNewId
(),
reference
=
"TESTSI-%s"
%
self
.
generateNewId
(),
url_string
=
s
elf
.
s
oftware_instance
.
getUrlString
(),
url_string
=
software_instance
.
getUrlString
(),
source_reference
=
s
elf
.
generateNewSoftwareTyp
e
(),
source_reference
=
s
oftware_instance
.
getSourceReferenc
e
(),
text_content
=
self
.
generateSafeXml
(),
text_content
=
self
.
generateSafeXml
(),
sla_xml
=
sla_xml
,
sla_xml
=
sla_xml
,
specialise
=
self
.
instance_tree
.
getRelativeUrl
(),
specialise
=
instance_tree
.
getRelativeUrl
(),
follow_up_value
=
self
.
project
follow_up_value
=
project
)
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'start_requested'
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'start_requested'
)
software_instance2
.
validate
()
software_instance2
.
validate
()
self
.
commit
()
self
.
tic
()
software_instance2
.
SoftwareInstance_tryToAllocatePartition
()
software_instance2
.
SoftwareInstance_tryToAllocatePartition
()
self
.
assertEqual
(
self
.
assertEqual
(
software_instance2
.
getAggregate
(
portal_type
=
'Compute Partition'
),
software_instance2
.
getAggregate
(
portal_type
=
'Compute Partition'
),
...
@@ -479,12 +500,12 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -479,12 +500,12 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
software_instance3
.
edit
(
software_instance3
.
edit
(
title
=
self
.
generateNewSoftwareTitle
(),
title
=
self
.
generateNewSoftwareTitle
(),
reference
=
"TESTSI-%s"
%
self
.
generateNewId
(),
reference
=
"TESTSI-%s"
%
self
.
generateNewId
(),
url_string
=
s
elf
.
s
oftware_instance
.
getUrlString
(),
url_string
=
software_instance
.
getUrlString
(),
source_reference
=
self
.
generateNewSoftwareType
(),
source_reference
=
self
.
generateNewSoftwareType
(),
text_content
=
self
.
generateSafeXml
(),
text_content
=
self
.
generateSafeXml
(),
sla_xml
=
sla_xml
,
sla_xml
=
sla_xml
,
specialise
=
self
.
instance_tree
.
getRelativeUrl
(),
specialise
=
instance_tree
.
getRelativeUrl
(),
follow_up_value
=
self
.
project
follow_up_value
=
project
)
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance3
,
'start_requested'
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance3
,
'start_requested'
)
software_instance3
.
validate
()
software_instance3
.
validate
()
...
@@ -502,22 +523,19 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -502,22 +523,19 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
Test that when we request instance with mode as 'unique_by_network',
Test that when we request instance with mode as 'unique_by_network',
instance is not deployed on compute_node with no network.
instance is not deployed on compute_node with no network.
"""
"""
self
.
_makeTree
(
self
.
project
)
software_instance
,
_
,
_
=
self
.
makeAllocableSoftwareInstance
()
self
.
_makeComputeNode
(
self
.
project
)
self
.
_installSoftware
(
self
.
compute_node
,
self
.
software_instance
.
getUrlString
())
self
.
assertEqual
(
None
,
s
elf
.
s
oftware_instance
.
getAggregateValue
(
self
.
assertEqual
(
None
,
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
portal_type
=
'Compute Partition'
))
s
elf
.
s
oftware_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
software_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
<instance>
<instance>
<parameter id='mode'>unique_by_network</parameter>
<parameter id='mode'>unique_by_network</parameter>
</instance>"""
)
</instance>"""
)
s
elf
.
s
oftware_instance
.
SoftwareInstance_tryToAllocatePartition
()
software_instance
.
SoftwareInstance_tryToAllocatePartition
()
self
.
assertEqual
(
self
.
assertEqual
(
None
,
None
,
s
elf
.
s
oftware_instance
.
getAggregate
(
portal_type
=
'Compute Partition'
)
software_instance
.
getAggregate
(
portal_type
=
'Compute Partition'
)
)
)
@
simulate
(
'Person_isAllowedToAllocate'
,
'*args, **kwargs'
,
'return True'
)
@
simulate
(
'Person_isAllowedToAllocate'
,
'*args, **kwargs'
,
'return True'
)
...
@@ -537,8 +555,8 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -537,8 +555,8 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
else
:
else
:
return
self
.
serialize_call
()
return
self
.
serialize_call
()
s
elf
.
_makeTree
(
self
.
project
)
s
oftware_instance
,
_
,
_
=
self
.
makeAllocableSoftwareInstance
(
)
s
elf
.
s
oftware_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
software_instance
.
setSlaXml
(
"""<?xml version='1.0' encoding='utf-8'?>
<instance>
<instance>
<parameter id='mode'>unique_by_network</parameter>
<parameter id='mode'>unique_by_network</parameter>
</instance>"""
)
</instance>"""
)
...
@@ -548,7 +566,7 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -548,7 +566,7 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
try
:
try
:
Base
.
serialize
=
verify_serialize_call
Base
.
serialize
=
verify_serialize_call
self
.
assertRaises
(
DummyTestException
,
self
.
assertRaises
(
DummyTestException
,
s
elf
.
s
oftware_instance
.
SoftwareInstance_tryToAllocatePartition
)
software_instance
.
SoftwareInstance_tryToAllocatePartition
)
finally
:
finally
:
Base
.
serialize
=
Base
.
serialize_call
Base
.
serialize
=
Base
.
serialize_call
...
@@ -565,22 +583,22 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -565,22 +583,22 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
<instance>
<instance>
<parameter id='mode'>unique_by_network</parameter>
<parameter id='mode'>unique_by_network</parameter>
</instance>"""
</instance>"""
self
.
_makeTree
(
self
.
project
)
software_instance
,
compute_node1
,
_
,
software_product
,
release_variation
,
type_variation
=
\
compute_node1
=
self
.
_makeComputeNode
(
self
.
project
)[
0
]
self
.
makeAllocableSoftwareInstanceAndProduct
()
compute_node2
=
self
.
_makeComputeNode
(
self
.
project
)[
0
]
self
.
_installSoftware
(
compute_node1
,
self
.
software_instance
.
getUrlString
())
instance_tree
=
software_instance
.
getSpecialiseValue
()
self
.
_installSoftware
(
compute_node2
,
self
.
software_instance
.
getUrlString
())
project
=
compute_node1
.
getFollowUpValue
()
compute_node2
,
_
=
self
.
makeAllocableComputeNode
(
project
,
software_product
,
release_variation
,
type_variation
)
computer_network
=
self
.
_makeComputerNetwork
()
new_id
=
self
.
generateNewId
()
computer_network
=
self
.
portal
.
computer_network_module
.
newContent
(
portal_type
=
'Computer Network'
,
title
=
"live_test_%s"
%
new_id
,
reference
=
"live_test_%s"
%
new_id
)
computer_network
.
validate
()
compute_node1
.
edit
(
subordination_value
=
computer_network
)
compute_node1
.
edit
(
subordination_value
=
computer_network
)
compute_node2
.
edit
(
subordination_value
=
computer_network
)
compute_node2
.
edit
(
subordination_value
=
computer_network
)
self
.
assertEqual
(
None
,
self
.
software_instance
.
getAggregateValue
(
self
.
tic
()
self
.
assertEqual
(
None
,
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
portal_type
=
'Compute Partition'
))
software_instance2
=
self
.
portal
.
software_instance_module
\
software_instance2
=
self
.
portal
.
software_instance_module
\
...
@@ -588,12 +606,12 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -588,12 +606,12 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
software_instance2
.
edit
(
software_instance2
.
edit
(
title
=
self
.
generateNewSoftwareTitle
(),
title
=
self
.
generateNewSoftwareTitle
(),
reference
=
"TESTSI-%s"
%
self
.
generateNewId
(),
reference
=
"TESTSI-%s"
%
self
.
generateNewId
(),
url_string
=
s
elf
.
s
oftware_instance
.
getUrlString
(),
url_string
=
software_instance
.
getUrlString
(),
source_reference
=
s
elf
.
generateNewSoftwareTyp
e
(),
source_reference
=
s
oftware_instance
.
getSourceReferenc
e
(),
text_content
=
self
.
generateSafeXml
(),
text_content
=
self
.
generateSafeXml
(),
sla_xml
=
sla_xml
,
sla_xml
=
sla_xml
,
specialise
=
self
.
instance_tree
.
getRelativeUrl
()
,
specialise
_value
=
instance_tree
,
follow_up_value
=
self
.
project
follow_up_value
=
project
)
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'start_requested'
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'start_requested'
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'validated'
)
self
.
portal
.
portal_workflow
.
_jumpToStateFor
(
software_instance2
,
'validated'
)
...
@@ -601,26 +619,26 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
...
@@ -601,26 +619,26 @@ class TestSlapOSAllocation(SlapOSTestCaseMixin):
self
.
assertEqual
(
None
,
self
.
assertEqual
(
None
,
s
elf
.
s
oftware_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
self
.
assertEqual
(
s
elf
.
s
oftware_instance
.
getSlapState
(),
'start_requested'
)
self
.
assertEqual
(
software_instance
.
getSlapState
(),
'start_requested'
)
self
.
assertEqual
(
s
elf
.
s
oftware_instance
.
getValidationState
(),
'validated'
)
self
.
assertEqual
(
software_instance
.
getValidationState
(),
'validated'
)
s
elf
.
s
oftware_instance
.
setSlaXml
(
sla_xml
)
software_instance
.
setSlaXml
(
sla_xml
)
s
elf
.
s
oftware_instance
.
SoftwareInstance_tryToAllocatePartition
()
software_instance
.
SoftwareInstance_tryToAllocatePartition
()
software_instance2
.
SoftwareInstance_tryToAllocatePartition
()
software_instance2
.
SoftwareInstance_tryToAllocatePartition
()
portal_workflow
=
s
elf
.
s
oftware_instance
.
portal_workflow
portal_workflow
=
software_instance
.
portal_workflow
last_workflow_item
=
portal_workflow
.
getInfoFor
(
ob
=
s
elf
.
s
oftware_instance
,
last_workflow_item
=
portal_workflow
.
getInfoFor
(
ob
=
software_instance
,
name
=
'comment'
,
wf_id
=
'edit_workflow'
)
name
=
'comment'
,
wf_id
=
'edit_workflow'
)
self
.
assertEqual
(
None
,
last_workflow_item
)
self
.
assertEqual
(
None
,
last_workflow_item
)
self
.
assertNotEqual
(
None
,
self
.
assertNotEqual
(
None
,
s
elf
.
s
oftware_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
))
# First is deployed
# First is deployed
self
.
assertEqual
(
self
.
assertEqual
(
computer_network
.
getReference
(),
computer_network
.
getReference
(),
s
elf
.
s
oftware_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
)
\
software_instance
.
getAggregateValue
(
portal_type
=
'Compute Partition'
)
\
.
getParentValue
().
getSubordinationReference
(),
.
getParentValue
().
getSubordinationReference
(),
)
)
# But second is not yet deployed because of pending activities containing tag
# But second is not yet deployed because of pending activities containing tag
...
...
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