Sha256: 704acccf46d4fce673c04181dbf414b6cc576a09a38bb402f24118ac88a2cab2
Contents?: true
Size: 1.12 KB
Versions: 2
Compression:
Stored size: 1.12 KB
Contents
# frozen_string_literal: true require 'open3' require_relative "helm_upgrade_logs/version" # Approach not ideal as it will for all containers to be ready and want to stream logs before that def wait_for_container_ready wait_pid = Process.spawn 'kubectl wait --for=condition=ContainersReady pod --selector "app.kubernetes.io/managed-by=Helm" --timeout=30s' Process.wait wait_pid end # Wait for pods with logs to be present # Not ideal due to https://github.com/kubernetes/kubernetes/issues/28746 def wait_for_pod_to_log 90.times { sleep 1 stdout, stderr, _ = Open3.capture3 "kubectl logs -lapp.kubernetes.io/managed-by=Helm,app.kubernetes.io/instance=#{$release_name}" if stderr.empty? && !stdout.strip.empty? puts 'Pods with logs found' break else puts "Waiting for pod logs: #{stderr}" end } end def get_pods stdout, stderr, _ = Open3.capture3 "kubectl get pods -lapp.kubernetes.io/instance=#{$release_name} -o name" if stderr.empty? stdout.lines.collect { |pod| pod.strip } else [] end end module HelmUpgradeLogs class Error < StandardError; end # Your code goes here... end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
helm_upgrade_logs-0.2.1 | lib/helm_upgrade_logs.rb |
helm_upgrade_logs-0.2.0 | lib/helm_upgrade_logs.rb |