Project: raku-alpine-docker

Configuration

configuration not found

Job

use Sparky::JobApi;

class Pipeline does Sparky::JobApi::Role {

  has Str $.cromt-project = tags()<cromt-project>;

  has Str $.action = tags()<action> || config()<projects>{$!cromt-project}<action> || "default";

  has Str $.options = tags()<options> || config()<projects>{$!cromt-project}<options> || "--verbose";

  has Str $.resolve-hosts = tags()<resolve-hosts> || "yes";

  has Str $.resolve-deps = tags()<resolve-deps> || "yes";

  has Str $.storage_project = tags()<storage_project> || "";

  has Str $.storage_job_id = tags()<storage_job_id> || "";

  has Str $.storage_api = config()<storage> || "http://127.0.0.1:4000";
  
  has Hash $.sparrowdo = config()<projects>{$!cromt-project}<sparrowdo> || {};

    method stage-main {

      my $project = config()<projects>{$!cromt-project}<queue-id>;
      my $conf = config()<projects>{$!cromt-project};
      my $j;
      
      if $conf<url> {
          my $api = $conf<url>;
          my $project = $conf<queue-id>;
          $j = $project ?? (self.new-job: :$api, :$project) !! (self.new-job: :$api);
          say "trigger job on host: {$api} | conf: {$conf.perl}";
      } else {
          my $project = $conf<queue-id>;
          $j = $project ?? (self.new-job: :$project) !! (self.new-job);
          say "trigger job on host: localhost | conf: {$conf.perl}";
      }

      my $storage = self.new-job: api => $.storage_api;  

      my %storage = $storage.info();

      my $description = $conf<title> || "{tags()<SPARKY_PROJECT>} [job run]";

      my $timeout = $conf<timeout> || 600;

      $j.queue: %(
        description => $description,
        tags => %(
          stage => "run",
          cromt-project => $.cromt-project,
          action => $.action,
          options => $.options,
          storage_project => %storage<project>,
          storage_job_id => %storage<job-id>,
          queue_id => $conf<queue-id>,
        ),
        sparrowdo => $.sparrowdo
      );

      my $st = self.wait-job($j,{ timeout => $timeout.Int });

      die $st.perl unless $st<OK> == 1;

      say $st.perl;

    }

    method stage-run {

      my $options = $.options;

      my $action = $.action;

      my $j = Sparky::JobApi.new( mine => True );

      my $stash = $j.get-stash();

      my $conf = config()<projects>{$.cromt-project};

      my $timeout = $conf<timeout> || 600;

      my $path = $conf<path>;

      say ">>> handle job config: ", $conf.perl;

      if $.resolve-deps eq "yes" and $conf<before> {

        say ">>> enter before block: ", $conf<before>.perl;

        my @jobs = self!run-job-dependency($conf<before>);

        say "waiting for dependencies jobs have finsihed ...";

        my $st = self.wait-jobs(@jobs,{ timeout => $timeout.Int });

        die $st.perl unless $st<OK> == @jobs.elems;

        say $st.perl;

      }

      if $.resolve-hosts eq "yes" && $conf<hosts><> {

          my @jobs;

          say ">>> enter hosts block: ", $conf<hosts>.perl;

          for $conf<hosts><> -> $host {

            my $job;

            if $host<url> || $conf<url> {
                my $api = $host<url> || $conf<url>;
                my $project = $host<queue-id> || $conf<queue-id>;
                $job = $project ?? (self.new-job: :$api, :$project) !! (self.new-job: :$api);
                say "trigger job on host: {$api} | host conf: {$host.perl} | conf: {$conf.perl}";
            } else {
                my $project = $host<queue-id> || $conf<queue-id>;
                $job = $project ?? (self.new-job: :$project) !! (self.new-job);
                say "trigger job on host: localhost | host conf: {$host.perl} | conf: {$conf.perl}";
            }

            if $host<vars> || $conf<vars> {
              say "save job vars ...";    
              $job.put-stash({ vars => $host<vars> || $conf<vars> || {} });
            } 

            my $description = $host<title> || $conf<title> || "(host) {$.cromt-project} [job run]";

            $job.queue: %(
              description => $description,
              tags => %(
                stage => "run",
                cromt-project => $.cromt-project,
                action => $host<action>,
                options => $options,
                resolve-hosts => "no",
                resolve-deps => "no",
                storage_project => $.storage_project,
                storage_job_id => $.storage_job_id,
              ),
              sparrowdo => $host<sparrowdo> || $.sparrowdo
            );

            @jobs.push: $job;

          }

          say "waiting for hosts jobs have finsihed ...";
          
          my $st = self.wait-jobs(@jobs,{ timeout => $timeout.Int });

          die $st.perl unless $st<OK> == @jobs.elems;

          say $st.perl;

      } else {
        my $envvars = $stash<vars> || $conf<vars> || {};   
        self!job-run: :$action,:$options,:$envvars,:$path;
      }
 
      if $.resolve-deps eq "yes" and $conf<after> {

        say ">>> enter after block: ", $conf<after>.perl;

        my @jobs = self!run-job-dependency($conf<after>);

        say "waiting for dependencies jobs have finsihed ...";

        my $st = self.wait-jobs(@jobs,{ timeout => $timeout });

        die $st.perl unless $st<OK> == @jobs.elems;

        say $st.perl;
      }

    }

    method !run-job-dependency ($jobs) {

      my @jobs;

      for $jobs<> -> $j {
  
        my $cromt-project = $j<name>;

        my $conf = config()<projects>{$cromt-project};

        if $.resolve-hosts eq "yes" and $j<hosts> {

          say "run-job-dependency - handle hosts: ", $j<hosts><>.perl;

          for $j<hosts><> -> $host {

            my $job;

            if $host<url> || $j<url> || $conf<url> {
                my $api = $host<url> || $j<url> || $conf<url>;
                my $project = $host<queue-id> || $j<queue-id>;
                $job = $project ?? (self.new-job: :$api, :$project) !! (self.new-job: :$api);
                say "trigger job on host: {$api} | host conf: {$host.perl} | deb conf: {$j.perl} | conf: {$conf.perl}";
            } else {
                my $project = $host<queue-id> || $j<queue-id>;
                $job = $project ?? (self.new-job: :$project) !! (self.new-job);
                say "trigger job on host: localhost | host conf: {$host.perl} | dep conf: {$j.perl} | conf: {$conf.perl}";
            }

            if $host<vars> || $j<vars> {
              say "save job vars ...";    
              $job.put-stash({ vars => $host<vars> || $j<vars> || {}});
            } 

            my $description = $host<title> || $j<title> || $conf<title> || "(dep host) {$cromt-project} [job run]";

            $job.queue: %(
              description => $description,
              tags => %(
                stage => "run",
                cromt-project => $cromt-project,
                action => $host<action> || $j<action>,
                options => $host<options> || $j<options>,
                resolve-hosts => "no",
                storage_project => $.storage_project,
                storage_job_id => $.storage_job_id,              
              ),
              sparrowdo => $host<sparrowdo> || $j<sparrowdo> || {},
            );

            @jobs.push: $job;

          }    
        } else {

          my $job;

          if $j<url> || $conf<url> {
              my $api = $j<url> || $conf<url>;
              my $project = $j<queue-id> || $conf<queue-id>;
              $job = $project ?? (self.new-job: :$api, :$project) !! (self.new-job: :$api);
              say "trigger job on host: {$api} | dep conf: {$j.perl} | conf: {$conf.perl}";
          } else {
              my $project = $j<queue-id> || $conf<queue-id>;
              $job = $project ?? (self.new-job: :$project) !! (self.new-job);
              say "trigger job on host: localhost | dep conf: {$j.perl} | conf: {$conf.perl}";
          }

          if $j<vars> {
            say "save job vars ...";    
            $job.put-stash({ vars => $j<vars> });
          }

          my $description =  $j<title> || $conf<title> || "(dep) {$cromt-project} [job run]";

          $job.queue: %(
            description => $description,
            tags => %(
              stage => "run",
              cromt-project => $cromt-project,
              action => $j<action>,
              options => $j<options>,
              storage_project => $.storage_project,
              storage_job_id => $.storage_job_id,
            ),
            sparrowdo => $j<sparrowdo> || $conf<sparrowdo> || {}
          );

          @jobs.push: $job;

        }

      }

      return @jobs;

    }

    method !job-run (:$action,:$options,:$envvars,:$path) {

      my $eff-path;

      if $path ~~ /^^ 'git@' || 'https://' / {
        directory-delete "scm";
        directory "scm";
        git-scm $path, %( to => "scm" );
        $eff-path = "{$*CWD}/scm";
      } else {
        $eff-path = $path.subst(/^ '~' "/" /,"{%*ENV<HOME>}/");
      }

      my $log-file = "{$*CWD}/job.log";
      my $status-file = "{$*CWD}/job.status.log";

      directory "{$eff-path}/.artifacts";

      if config()<projects>{$.cromt-project}<artifacts> && config()<projects>{$.cromt-project}<artifacts><in> {
        my $job = self.new-job: job-id => $.storage_job_id, project => $.storage_project, api => $.storage_api;
        for config()<projects>{$.cromt-project}<artifacts><in><> -> $f {
          say "copy artifact $f from storage to {$eff-path}/.artifacts/";
          "{$eff-path}/.artifacts/{$f}".IO.spurt($job.get-file($f),:bin);
        }
      } 

      for $action.split(/\s+/) -> $act {  

        say ">> run job path={$path} action={$act} options={$options} envvars={$envvars.perl}";
        
        bash qq:to/HERE/, %( cwd => $eff-path, envvars => $envvars, description => "tomtit job"  );
          #tom $options $act 1>$log-file 2>$log-file
          #echo \$? > $status-file
          SP6_LOG_NO_TIMESTAMPS=1 tom $options $act
        HERE

        # my $job-id = now.Int;

        # mkdir "{%*ENV<HOME>}/.cromtit/reports/{$job-id}";

        # say "copy report and status to {%*ENV<HOME>}/.cromtit/reports/{$job-id} ...";

        # copy($log-file,"{%*ENV<HOME>}/.cromtit/reports/{$job-id}/{$log-file.IO.basename}");

        # copy($status-file,"{%*ENV<HOME>}/.cromtit/reports/{$job-id}/{$status-file.IO.basename}");

      }

      if config()<projects>{$.cromt-project}<artifacts> && config()<projects>{$.cromt-project}<artifacts><out> {
        my $job = self.new-job: job-id => $.storage_job_id, project => $.storage_project, api => $.storage_api;
        for config()<projects>{$.cromt-project}<artifacts><out><> -> $f {
          say "copy artifact {$f<file>} to storage";
          $job.put-file("{$eff-path}/{$f<path>}",$f<file>);
        }
      } 

    }

  }


Pipeline.new.run;