require 'test/unit' require 'mocha/test_unit' require 'fluent/test' require 'aws-sdk-core' module CloudwatchLogsTestHelper private def logs options = {} options[:credentials] = Aws::Credentials.new(ENV['aws_key_id'], ENV['aws_sec_key']) if ENV['aws_key_id'] && ENV['aws_sec_key'] options[:region] = ENV['region'] if ENV['region'] options[:http_proxy] = ENV['http_proxy'] if ENV['http_proxy'] @logs ||= Aws::CloudWatchLogs::Client.new(options) end def log_group_name @log_group_name ||= "fluent-plugin-cloudwatch-test-#{Time.now.to_f}" end def aws_key_id "aws_key_id #{ENV['aws_key_id']}" if ENV['aws_key_id'] end def aws_sec_key "aws_sec_key #{ENV['aws_sec_key']}" if ENV['aws_sec_key'] end def region "region #{ENV['region']}" if ENV['region'] end def log_stream_name(log_stream_name_prefix = nil) if !@log_stream_name new_log_stream(log_stream_name_prefix) end @log_stream_name end def new_log_stream(log_stream_name_prefix = nil) @log_stream_name = log_stream_name_prefix ? log_stream_name_prefix + Time.now.to_f.to_s : Time.now.to_f.to_s end def clear_log_group [log_group_name, fluentd_tag].each do |name| begin logs.delete_log_group(log_group_name: name) rescue Aws::CloudWatchLogs::Errors::ResourceNotFoundException # pass end end end def fluentd_tag @fluentd_tag ||= "fluent.plugin.cloudwatch.test.#{Time.now.to_f}" end def create_log_stream() begin logs.create_log_group(log_group_name: log_group_name) rescue Aws::CloudWatchLogs::Errors::ResourceAlreadyExistsException # pass end begin logs.create_log_stream(log_group_name: log_group_name, log_stream_name: log_stream_name) rescue Aws::CloudWatchLogs::Errors::ResourceAlreadyExistsException # pass end end def get_log_events(group = log_group_name, stream = log_stream_name) logs.get_log_events(log_group_name: group, log_stream_name: stream).events end def put_log_events(events) args = { log_events: events, log_group_name: log_group_name, log_stream_name: log_stream_name, } logs.put_log_events(args) end end