import boto3 import pytest import sure # noqa # pylint: disable=unused-import from botocore.exceptions import ClientError from moto import mock_managedblockchain from . import helpers @mock_managedblockchain def test_create_node(): conn = boto3.client("managedblockchain", region_name="us-east-1") # Create network response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] member_id = response["MemberId"] # Create a node response = conn.create_node( NetworkId=network_id, MemberId=member_id, NodeConfiguration=helpers.default_nodeconfiguration, ) node_id = response["NodeId"] # Find node in full list response = conn.list_nodes(NetworkId=network_id, MemberId=member_id) nodes = response["Nodes"] nodes.should.have.length_of(1) helpers.node_id_exist_in_list(nodes, node_id).should.equal(True) # Get node details response = conn.get_node(NetworkId=network_id, MemberId=member_id, NodeId=node_id) response["Node"]["AvailabilityZone"].should.equal("us-east-1a") # Update node logconfignewenabled = not helpers.default_nodeconfiguration[ "LogPublishingConfiguration" ]["Fabric"]["ChaincodeLogs"]["Cloudwatch"]["Enabled"] logconfignew = { "Fabric": {"ChaincodeLogs": {"Cloudwatch": {"Enabled": logconfignewenabled}}} } conn.update_node( NetworkId=network_id, MemberId=member_id, NodeId=node_id, LogPublishingConfiguration=logconfignew, ) # Delete node conn.delete_node(NetworkId=network_id, MemberId=member_id, NodeId=node_id) # Find node in full list response = conn.list_nodes(NetworkId=network_id, MemberId=member_id) nodes = response["Nodes"] nodes.should.have.length_of(1) helpers.node_id_exist_in_list(nodes, node_id).should.equal(True) # Find node in full list - only DELETED response = conn.list_nodes( NetworkId=network_id, MemberId=member_id, Status="DELETED" ) nodes = response["Nodes"] nodes.should.have.length_of(1) helpers.node_id_exist_in_list(nodes, node_id).should.equal(True) # But cannot get with pytest.raises(ClientError) as ex: conn.get_node(NetworkId=network_id, MemberId=member_id, NodeId=node_id) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain(f"Node {node_id} not found") @mock_managedblockchain def test_create_node_standard_edition(): conn = boto3.client("managedblockchain", region_name="us-east-1") frameworkconfiguration = {"Fabric": {"Edition": "STANDARD"}} response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] member_id = response["MemberId"] # Instance type only allowed with standard edition logconfigbad = dict(helpers.default_nodeconfiguration) logconfigbad["InstanceType"] = "bc.t3.large" response = conn.create_node( NetworkId=network_id, MemberId=member_id, NodeConfiguration=logconfigbad ) node_id = response["NodeId"] # Get node details response = conn.get_node(NetworkId=network_id, MemberId=member_id, NodeId=node_id) response["Node"]["InstanceType"].should.equal("bc.t3.large") # Need another member so the network does not get deleted # Create proposal response = conn.create_proposal( NetworkId=network_id, MemberId=member_id, Actions=helpers.default_policy_actions ) proposal_id = response["ProposalId"] # Vote yes response = conn.vote_on_proposal( NetworkId=network_id, ProposalId=proposal_id, VoterMemberId=member_id, Vote="YES", ) # Get the invitation response = conn.list_invitations() invitation_id = response["Invitations"][0]["InvitationId"] # Create the member response = conn.create_member( InvitationId=invitation_id, NetworkId=network_id, MemberConfiguration=helpers.create_member_configuration( "testmember2", "admin", "Admin12345", False, "Test Member 2" ), ) # Remove member 1 - should remove nodes conn.delete_member(NetworkId=network_id, MemberId=member_id) # Should now be an exception with pytest.raises(ClientError) as ex: conn.list_nodes(NetworkId=network_id, MemberId=member_id) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain(f"Member {member_id} not found") @mock_managedblockchain def test_create_too_many_nodes(): conn = boto3.client("managedblockchain", region_name="us-east-1") # Create network response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] member_id = response["MemberId"] # Create a node response = conn.create_node( NetworkId=network_id, MemberId=member_id, NodeConfiguration=helpers.default_nodeconfiguration, ) # Create another node response = conn.create_node( NetworkId=network_id, MemberId=member_id, NodeConfiguration=helpers.default_nodeconfiguration, ) # Find node in full list response = conn.list_nodes(NetworkId=network_id, MemberId=member_id) nodes = response["Nodes"] nodes.should.have.length_of(2) # Try to create one too many nodes with pytest.raises(ClientError) as ex: conn.create_node( NetworkId=network_id, MemberId=member_id, NodeConfiguration=helpers.default_nodeconfiguration, ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceLimitExceededException") err["Message"].should.contain( f"Maximum number of nodes exceeded in member {member_id}" ) @mock_managedblockchain def test_create_node_badnetwork(): conn = boto3.client("managedblockchain", region_name="us-east-1") with pytest.raises(ClientError) as ex: conn.create_node( NetworkId="n-ABCDEFGHIJKLMNOP0123456789", MemberId="m-ABCDEFGHIJKLMNOP0123456789", NodeConfiguration=helpers.default_nodeconfiguration, ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Network n-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_create_node_badmember(): conn = boto3.client("managedblockchain", region_name="us-east-1") response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] with pytest.raises(ClientError) as ex: conn.create_node( NetworkId=network_id, MemberId="m-ABCDEFGHIJKLMNOP0123456789", NodeConfiguration=helpers.default_nodeconfiguration, ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Member m-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_create_node_badnodeconfig(): conn = boto3.client("managedblockchain", region_name="us-east-1") response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] member_id = response["MemberId"] # Incorrect instance type logconfigbad = dict(helpers.default_nodeconfiguration) logconfigbad["InstanceType"] = "foo" with pytest.raises(ClientError) as ex: conn.create_node( NetworkId=network_id, MemberId=member_id, NodeConfiguration=logconfigbad ) err = ex.value.response["Error"] err["Code"].should.equal("InvalidRequestException") err["Message"].should.contain("Requested instance foo isn't supported.") # Incorrect instance type for edition logconfigbad = dict(helpers.default_nodeconfiguration) logconfigbad["InstanceType"] = "bc.t3.large" with pytest.raises(ClientError) as ex: conn.create_node( NetworkId=network_id, MemberId=member_id, NodeConfiguration=logconfigbad ) err = ex.value.response["Error"] err["Code"].should.equal("InvalidRequestException") err["Message"].should.contain( "Instance type bc.t3.large is not supported with STARTER Edition networks." ) # Incorrect availability zone logconfigbad = dict(helpers.default_nodeconfiguration) logconfigbad["AvailabilityZone"] = "us-east-11" with pytest.raises(ClientError) as ex: conn.create_node( NetworkId=network_id, MemberId=member_id, NodeConfiguration=logconfigbad ) err = ex.value.response["Error"] err["Code"].should.equal("InvalidRequestException") err["Message"].should.contain("Availability Zone is not valid") @mock_managedblockchain def test_list_nodes_badnetwork(): conn = boto3.client("managedblockchain", region_name="us-east-1") with pytest.raises(ClientError) as ex: conn.list_nodes( NetworkId="n-ABCDEFGHIJKLMNOP0123456789", MemberId="m-ABCDEFGHIJKLMNOP0123456789", ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Network n-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_list_nodes_badmember(): conn = boto3.client("managedblockchain", region_name="us-east-1") response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] with pytest.raises(ClientError) as ex: conn.list_nodes(NetworkId=network_id, MemberId="m-ABCDEFGHIJKLMNOP0123456789") err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Member m-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_get_node_badnetwork(): conn = boto3.client("managedblockchain", region_name="us-east-1") with pytest.raises(ClientError) as ex: conn.get_node( NetworkId="n-ABCDEFGHIJKLMNOP0123456789", MemberId="m-ABCDEFGHIJKLMNOP0123456789", NodeId="nd-ABCDEFGHIJKLMNOP0123456789", ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Network n-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_get_node_badmember(): conn = boto3.client("managedblockchain", region_name="us-east-1") response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] with pytest.raises(ClientError) as ex: conn.get_node( NetworkId=network_id, MemberId="m-ABCDEFGHIJKLMNOP0123456789", NodeId="nd-ABCDEFGHIJKLMNOP0123456789", ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Member m-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_get_node_badnode(): conn = boto3.client("managedblockchain", region_name="us-east-1") response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] member_id = response["MemberId"] with pytest.raises(ClientError) as ex: conn.get_node( NetworkId=network_id, MemberId=member_id, NodeId="nd-ABCDEFGHIJKLMNOP0123456789", ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Node nd-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_delete_node_badnetwork(): conn = boto3.client("managedblockchain", region_name="us-east-1") with pytest.raises(ClientError) as ex: conn.delete_node( NetworkId="n-ABCDEFGHIJKLMNOP0123456789", MemberId="m-ABCDEFGHIJKLMNOP0123456789", NodeId="nd-ABCDEFGHIJKLMNOP0123456789", ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Network n-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_delete_node_badmember(): conn = boto3.client("managedblockchain", region_name="us-east-1") response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] with pytest.raises(ClientError) as ex: conn.delete_node( NetworkId=network_id, MemberId="m-ABCDEFGHIJKLMNOP0123456789", NodeId="nd-ABCDEFGHIJKLMNOP0123456789", ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Member m-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_delete_node_badnode(): conn = boto3.client("managedblockchain", region_name="us-east-1") response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] member_id = response["MemberId"] with pytest.raises(ClientError) as ex: conn.delete_node( NetworkId=network_id, MemberId=member_id, NodeId="nd-ABCDEFGHIJKLMNOP0123456789", ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Node nd-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_update_node_badnetwork(): conn = boto3.client("managedblockchain", region_name="us-east-1") with pytest.raises(ClientError) as ex: conn.update_node( NetworkId="n-ABCDEFGHIJKLMNOP0123456789", MemberId="m-ABCDEFGHIJKLMNOP0123456789", NodeId="nd-ABCDEFGHIJKLMNOP0123456789", LogPublishingConfiguration=helpers.default_nodeconfiguration[ "LogPublishingConfiguration" ], ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Network n-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_update_node_badmember(): conn = boto3.client("managedblockchain", region_name="us-east-1") response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] with pytest.raises(ClientError) as ex: conn.update_node( NetworkId=network_id, MemberId="m-ABCDEFGHIJKLMNOP0123456789", NodeId="nd-ABCDEFGHIJKLMNOP0123456789", LogPublishingConfiguration=helpers.default_nodeconfiguration[ "LogPublishingConfiguration" ], ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Member m-ABCDEFGHIJKLMNOP0123456789 not found") @mock_managedblockchain def test_update_node_badnode(): conn = boto3.client("managedblockchain", region_name="us-east-1") response = conn.create_network( Name="testnetwork1", Description="Test Network 1", Framework="HYPERLEDGER_FABRIC", FrameworkVersion="1.2", FrameworkConfiguration=helpers.default_frameworkconfiguration, VotingPolicy=helpers.default_votingpolicy, MemberConfiguration=helpers.default_memberconfiguration, ) network_id = response["NetworkId"] member_id = response["MemberId"] with pytest.raises(ClientError) as ex: conn.update_node( NetworkId=network_id, MemberId=member_id, NodeId="nd-ABCDEFGHIJKLMNOP0123456789", LogPublishingConfiguration=helpers.default_nodeconfiguration[ "LogPublishingConfiguration" ], ) err = ex.value.response["Error"] err["Code"].should.equal("ResourceNotFoundException") err["Message"].should.contain("Node nd-ABCDEFGHIJKLMNOP0123456789 not found")