#!perl -T

use strict;
use warnings;

use Data::Dumper;

use Data::Validate::Type;
use Test::Exception;
use Test::More;

use WebService::DataDog;


eval 'use DataDogConfig';
$@
	? plan( skip_all => 'Local connection information for DataDog required to run tests.' )
	: plan( tests => 10 );

my $config = DataDogConfig->new();

# Create an object to communicate with DataDog
my $datadog = WebService::DataDog->new( %$config );
ok(
	defined( $datadog ),
	'Create a new WebService::DataDog object.',
);


my $alert_obj = $datadog->build('Alert');
ok(
	defined( $alert_obj ),
	'Create a new WebService::DataDog::Alert object.',
);
my $response;


throws_ok(
	sub
	{
		$response = $alert_obj->retrieve();
	},
	qr/Argument.*required/,
	'Dies on missing alert id argument.',
);

throws_ok(
	sub
	{
		$response = $alert_obj->retrieve( id => "abc" );
	},
	qr/id must be a number/,
	'Dies on invalid alert id.',
);

ok(
	open( FILE, 'webservice-datadog-alert-alertid.tmp'),
	'Open temp file to read alert id'
);

my $alert_id;

ok(
	$alert_id = do { local $/; <FILE> },
	'Read in alert id'
);

ok(
	close FILE,
	'Close temp file'
);

lives_ok(
	sub
	{
		$response = $alert_obj->retrieve( id => $alert_id );
	},
	'Request info on specific alert.',
);

ok(
	defined( $response ),
	'Response was received.'
);

ok(
	Data::Validate::Type::is_hashref( $response ),
	'Response is a hashref.',
);