NAME
Teamcity::Executor - Executor of TeamCity build configurations
SYNOPSIS 1 - asynchronous usage
use Teamcity::Executor;
use IO::Async::Loop;
use Log::Any::Adapter;
Log::Any::Adapter->set(
'Dispatch',
outputs => [
[
'Screen',
min_level => 'debug',
stderr => 1,
newline => 1
]
]
);
my $loop = IO::Async::Loop->new;
my $tc = Teamcity::Executor->new(
credentials => {
url => 'https://teamcity.example.com',
user => 'user',
pass => 'password',
},
build_id_mapping => {
hello_world => 'playground_HelloWorld',
hello_name => 'playground_HelloName',
}
poll_interval => 10,
loop => $loop,
);
$tc->register_polling_timer();
my $future = $tc->run('hello_name', { name => 'TeamCity' })->then(
sub {
my ($build) = @_;
print "Build succeeded\n";
my $greeting = $tc->get_artifact_content($build, 'greeting.txt');
print "Content of greeting.txt artifact: $greeting\n";
},
sub {
print "Build failed\n";
exit 1
}
);
my $touch_future = $tc->touch('hello_name', { name => 'TeamCity' })->then(
sub {
my ($build) = @_;
print "Touch build started\n";
$loop->stop();
},
sub {
print "Touch build failed to start\n";
exit 1
}
);
$loop->run();
SYNOPSIS 2 - synchronous usage
use Teamcity::Executor;
use Log::Any::Adapter;
Log::Any::Adapter->set(
'Dispatch',
outputs => [
[
'Screen',
min_level => 'debug',
stderr => 1,
newline => 1
]
]
);
my $tc = Teamcity::Executor->new(
credentials => {
url => 'https://teamcity.example.com',
user => 'user',
pass => 'password',
},
build_id_mapping => {
hello_world => 'playground_HelloWorld',
hello_name => 'playground_HelloName',
}
);
my $resp = $tc->touch_without_future('hello_name', {});
print "id: $resp->{id}\n";
print "webUrl: $resp->{webUrl}\n";
DESCRIPTION
Teamcity::Executor is a module for executing Teamcity build configurations. When you execute one, you'll receive a future of the build. Teamcity::Executor polls TeamCity and when it finds the build has ended, it resolves the future.
LICENSE
Copyright (C) Avast Software
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
AUTHOR
Miroslav Tynovsky <tynovsky@avast.com>