Sha256: 5d4b0722846e6d8af9ed9ad93c4e49a370d6cda15e3bb960a0384afa3ebedb67
Contents?: true
Size: 936 Bytes
Versions: 2
Compression:
Stored size: 936 Bytes
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 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.1.6 | lib/helm_upgrade_logs.rb |
helm_upgrade_logs-0.1.5 | lib/helm_upgrade_logs.rb |