Shindo.tests('AWS::EFS | file systems', ['aws', 'efs']) do suffix = rand(65535).to_s(16) @creation_token = "fogtest#{suffix}" tests('success') do tests("#create_file_system('#{@creation_token}')").formats(AWS::EFS::Formats::FILE_SYSTEM_FORMAT) do result = Fog::AWS[:efs].create_file_system(@creation_token).body returns('creating') { result['LifeCycleState'] } result end tests("#describe_file_systems").formats(AWS::EFS::Formats::DESCRIBE_FILE_SYSTEMS_RESULT) do Fog::AWS[:efs].describe_file_systems.body end tests("#describe_file_systems(creation_token: #{@creation_token})").formats(AWS::EFS::Formats::DESCRIBE_FILE_SYSTEMS_RESULT) do result = Fog::AWS[:efs].describe_file_systems(:creation_token => @creation_token).body returns(@creation_token) { result["FileSystems"].first["CreationToken"] } result end file_system_id = Fog::AWS[:efs].describe_file_systems(:creation_token => @creation_token).body["FileSystems"].first["FileSystemId"] file_system = Fog::AWS[:efs].file_systems.get(file_system_id) tests("#describe_file_systems(id: #{file_system_id})").formats(AWS::EFS::Formats::DESCRIBE_FILE_SYSTEMS_RESULT) do Fog::AWS[:efs].describe_file_systems(:id => file_system_id).body end if Fog.mocking? vpc = Fog::Compute[:aws].vpcs.create(:cidr_block => "10.0.0.0/16") subnet = Fog::Compute[:aws].subnets.create( :vpc_id => vpc.id, :cidr_block => "10.0.1.0/24" ) default_security_group = Fog::Compute[:aws].security_groups.detect { |sg| sg.description == 'default_elb security group' } else vpc = Fog::Compute[:aws].vpcs.first subnet = vpc.subnets.first default_security_group = Fog::Compute[:aws].security_groups.detect { |sg| sg.description == 'default VPC security group' } end security_group = Fog::Compute[:aws].security_groups.create( :vpc_id => vpc.id, :name => "fog#{suffix}", :description => "fog#{suffix}" ) raises(Fog::AWS::EFS::InvalidSubnet, "invalid subnet ID: foobar#{suffix}") do Fog::AWS[:efs].create_mount_target(file_system_id, "foobar#{suffix}") end raises(Fog::AWS::EFS::NotFound, "invalid file system ID: foobar#{suffix}") do Fog::AWS[:efs].create_mount_target("foobar#{suffix}", subnet.identity) end if Fog.mocking? tests("#create_mount_target") do Fog::AWS[:efs].data[:file_systems][file_system_id]["LifeCycleState"] = 'creating' raises(Fog::AWS::EFS::IncorrectFileSystemLifeCycleState) do Fog::AWS[:efs].create_mount_target(file_system_id, subnet.identity) end Fog::AWS[:efs].data[:file_systems][file_system_id]["LifeCycleState"] = 'available' end end raises(Fog::AWS::EFS::NotFound, "invalid security group ID: foobar#{suffix}") do Fog::AWS[:efs].create_mount_target(file_system_id, subnet.identity, 'SecurityGroups' => ["foobar#{suffix}"]) end tests("#create_mount_target(#{file_system_id}, #{subnet.identity})").formats(AWS::EFS::Formats::MOUNT_TARGET_FORMAT) do Fog::AWS[:efs].create_mount_target(file_system_id, subnet.identity).body end tests("#describe_mount_targets(file_system_id: #{file_system_id})").formats(AWS::EFS::Formats::DESCRIBE_MOUNT_TARGETS_RESULT) do Fog::AWS[:efs].describe_mount_targets(:file_system_id => file_system_id).body end mount_target_id = Fog::AWS[:efs].describe_mount_targets(:file_system_id => file_system_id).body["MountTargets"].first["MountTargetId"] tests("#describe_mount_target_security_groups(#{mount_target_id})").formats(AWS::EFS::Formats::DESCRIBE_MOUNT_TARGET_SECURITY_GROUPS_FORMAT) do result = Fog::AWS[:efs].describe_mount_target_security_groups(mount_target_id).body returns([default_security_group.group_id]) { result["SecurityGroups"] } result end raises(Fog::AWS::EFS::Error, 'Must provide at least one security group.') do Fog::AWS[:efs].modify_mount_target_security_groups(mount_target_id, []) end tests("#modify_mount_target_security_groups(#{mount_target_id}, [#{security_group.group_id}])") do returns(204) do Fog::AWS[:efs].modify_mount_target_security_groups(mount_target_id, [security_group.group_id]).status end end Fog.wait_for { Fog::AWS[:efs].describe_mount_target_security_groups(mount_target_id).body["SecurityGroups"] != [default_security_group.group_id] } tests("#describe_mount_target_security_groups(#{mount_target_id})").formats(AWS::EFS::Formats::DESCRIBE_MOUNT_TARGET_SECURITY_GROUPS_FORMAT) do result = Fog::AWS[:efs].describe_mount_target_security_groups(mount_target_id).body returns([security_group.group_id]) { result["SecurityGroups"] } result end tests("#describe_mount_targets(id: #{mount_target_id})").formats(AWS::EFS::Formats::DESCRIBE_MOUNT_TARGETS_RESULT) do Fog::AWS[:efs].describe_mount_targets(:id => mount_target_id).body end raises(Fog::AWS::EFS::NotFound, 'Mount target does not exist.') do Fog::AWS[:efs].describe_mount_targets(:id => "foobar") end raises(Fog::AWS::EFS::Error, 'file system ID or mount target ID must be specified') do Fog::AWS[:efs].describe_mount_targets end raises(Fog::AWS::EFS::NotFound, "invalid mount target id: foobar#{suffix}") do Fog::AWS[:efs].delete_mount_target("foobar#{suffix}") end tests("#delete_mount_target(id: #{mount_target_id})") do returns(true) do result = Fog::AWS[:efs].delete_mount_target(mount_target_id) result.body.empty? end end file_system.wait_for { number_of_mount_targets == 0 } if Fog.mocking? Fog::AWS[:efs].data[:file_systems][file_system_id]["NumberOfMountTargets"] = 1 raises(Fog::AWS::EFS::FileSystemInUse) do Fog::AWS[:efs].delete_file_system(file_system_id) end Fog::AWS[:efs].data[:file_systems][file_system_id]["NumberOfMountTargets"] = 0 end raises(Fog::AWS::EFS::NotFound, "invalid file system ID: foobar#{suffix}") do Fog::AWS[:efs].delete_file_system("foobar#{suffix}") end tests("#delete_file_system") do returns(true) do result = Fog::AWS[:efs].delete_file_system(file_system_id) result.body.empty? end end security_group.destroy end end