makit 0.0.158 → 0.0.162

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (180) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +41 -41
  3. data/exe/makit +5 -5
  4. data/lib/makit/apache.rb +28 -28
  5. data/lib/makit/auto.rb +48 -48
  6. data/lib/makit/azure/blob_storage.rb +257 -257
  7. data/lib/makit/azure/cli.rb +284 -284
  8. data/lib/makit/cli/base.rb +17 -17
  9. data/lib/makit/cli/build_commands.rb +500 -500
  10. data/lib/makit/cli/generators/base_generator.rb +74 -74
  11. data/lib/makit/cli/generators/dotnet_generator.rb +50 -50
  12. data/lib/makit/cli/generators/generator_factory.rb +49 -49
  13. data/lib/makit/cli/generators/node_generator.rb +50 -50
  14. data/lib/makit/cli/generators/ruby_generator.rb +77 -77
  15. data/lib/makit/cli/generators/rust_generator.rb +50 -50
  16. data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -167
  17. data/lib/makit/cli/generators/templates/node_templates.rb +161 -161
  18. data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -26
  19. data/lib/makit/cli/generators/templates/ruby/gemspec.rb +41 -41
  20. data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -33
  21. data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -35
  22. data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -63
  23. data/lib/makit/cli/generators/templates/ruby/test.rb +39 -39
  24. data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -29
  25. data/lib/makit/cli/generators/templates/ruby/version.rb +29 -29
  26. data/lib/makit/cli/generators/templates/rust_templates.rb +128 -128
  27. data/lib/makit/cli/main.rb +78 -78
  28. data/lib/makit/cli/pipeline_commands.rb +311 -311
  29. data/lib/makit/cli/project_commands.rb +868 -868
  30. data/lib/makit/cli/repository_commands.rb +661 -661
  31. data/lib/makit/cli/strategy_commands.rb +207 -207
  32. data/lib/makit/cli/utility_commands.rb +521 -521
  33. data/lib/makit/commands/factory.rb +359 -359
  34. data/lib/makit/commands/middleware/base.rb +73 -73
  35. data/lib/makit/commands/middleware/cache.rb +248 -248
  36. data/lib/makit/commands/middleware/command_logger.rb +312 -312
  37. data/lib/makit/commands/middleware/validator.rb +269 -269
  38. data/lib/makit/commands/request.rb +316 -316
  39. data/lib/makit/commands/result.rb +323 -323
  40. data/lib/makit/commands/runner.rb +386 -386
  41. data/lib/makit/commands/strategies/base.rb +171 -171
  42. data/lib/makit/commands/strategies/child_process.rb +162 -162
  43. data/lib/makit/commands/strategies/factory.rb +136 -136
  44. data/lib/makit/commands/strategies/synchronous.rb +139 -139
  45. data/lib/makit/commands.rb +50 -50
  46. data/lib/makit/configuration/dotnet_project.rb +48 -48
  47. data/lib/makit/configuration/gitlab_helper.rb +61 -61
  48. data/lib/makit/configuration/project.rb +292 -292
  49. data/lib/makit/configuration/rakefile_helper.rb +43 -43
  50. data/lib/makit/configuration/step.rb +34 -34
  51. data/lib/makit/configuration/timeout.rb +74 -74
  52. data/lib/makit/configuration.rb +21 -21
  53. data/lib/makit/content/default_gitignore.rb +7 -7
  54. data/lib/makit/content/default_gitignore.txt +225 -225
  55. data/lib/makit/content/default_rakefile.rb +13 -13
  56. data/lib/makit/content/gem_rakefile.rb +16 -16
  57. data/lib/makit/context.rb +1 -1
  58. data/lib/makit/data.rb +49 -49
  59. data/lib/makit/directories.rb +170 -170
  60. data/lib/makit/directory.rb +262 -262
  61. data/lib/makit/docs/files.rb +89 -89
  62. data/lib/makit/docs/rake.rb +102 -102
  63. data/lib/makit/dotnet/cli.rb +69 -69
  64. data/lib/makit/dotnet/project.rb +217 -217
  65. data/lib/makit/dotnet/solution.rb +38 -38
  66. data/lib/makit/dotnet/solution_classlib.rb +239 -239
  67. data/lib/makit/dotnet/solution_console.rb +264 -264
  68. data/lib/makit/dotnet/solution_maui.rb +354 -354
  69. data/lib/makit/dotnet/solution_wasm.rb +275 -275
  70. data/lib/makit/dotnet/solution_wpf.rb +304 -304
  71. data/lib/makit/dotnet.rb +102 -102
  72. data/lib/makit/email.rb +90 -90
  73. data/lib/makit/environment.rb +142 -142
  74. data/lib/makit/examples/runner.rb +370 -370
  75. data/lib/makit/exceptions.rb +45 -45
  76. data/lib/makit/fileinfo.rb +32 -32
  77. data/lib/makit/files.rb +43 -43
  78. data/lib/makit/gems.rb +49 -40
  79. data/lib/makit/git/cli.rb +103 -78
  80. data/lib/makit/git/repository.rb +100 -100
  81. data/lib/makit/git.rb +104 -104
  82. data/lib/makit/gitlab/pipeline.rb +857 -857
  83. data/lib/makit/gitlab/pipeline_service_impl.rb +1535 -1535
  84. data/lib/makit/gitlab_runner.rb +59 -59
  85. data/lib/makit/humanize.rb +218 -218
  86. data/lib/makit/indexer.rb +47 -47
  87. data/lib/makit/io/filesystem.rb +111 -111
  88. data/lib/makit/io/filesystem_service_impl.rb +337 -337
  89. data/lib/makit/lint.rb +212 -212
  90. data/lib/makit/logging/configuration.rb +309 -309
  91. data/lib/makit/logging/format_registry.rb +84 -84
  92. data/lib/makit/logging/formatters/base.rb +39 -39
  93. data/lib/makit/logging/formatters/console_formatter.rb +140 -140
  94. data/lib/makit/logging/formatters/json_formatter.rb +65 -65
  95. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
  96. data/lib/makit/logging/formatters/text_formatter.rb +64 -64
  97. data/lib/makit/logging/log_request.rb +119 -119
  98. data/lib/makit/logging/logger.rb +199 -199
  99. data/lib/makit/logging/sinks/base.rb +91 -91
  100. data/lib/makit/logging/sinks/console.rb +72 -72
  101. data/lib/makit/logging/sinks/file_sink.rb +92 -92
  102. data/lib/makit/logging/sinks/structured.rb +123 -123
  103. data/lib/makit/logging/sinks/unified_file_sink.rb +296 -296
  104. data/lib/makit/logging.rb +578 -578
  105. data/lib/makit/markdown.rb +75 -75
  106. data/lib/makit/mp/basic_object_mp.rb +17 -17
  107. data/lib/makit/mp/command_mp.rb +13 -13
  108. data/lib/makit/mp/command_request.mp.rb +17 -17
  109. data/lib/makit/mp/project_mp.rb +199 -199
  110. data/lib/makit/mp/string_mp.rb +205 -205
  111. data/lib/makit/nuget.rb +243 -74
  112. data/lib/makit/nuget_cache.rb +123 -0
  113. data/lib/makit/podman/podman.rb +458 -458
  114. data/lib/makit/podman/podman_service_impl.rb +1081 -1081
  115. data/lib/makit/port.rb +32 -32
  116. data/lib/makit/port_utility.rb +128 -0
  117. data/lib/makit/process.rb +377 -377
  118. data/lib/makit/protoc.rb +112 -112
  119. data/lib/makit/rake/cli.rb +196 -196
  120. data/lib/makit/rake/trace_controller.rb +174 -174
  121. data/lib/makit/rake.rb +81 -81
  122. data/lib/makit/ruby/cli.rb +185 -185
  123. data/lib/makit/ruby.rb +25 -25
  124. data/lib/makit/rubygems.rb +137 -137
  125. data/lib/makit/secrets/azure_key_vault.rb +322 -322
  126. data/lib/makit/secrets/azure_secrets.rb +183 -183
  127. data/lib/makit/secrets/local_secrets.rb +72 -72
  128. data/lib/makit/secrets/secrets_manager.rb +105 -105
  129. data/lib/makit/secrets.rb +16 -16
  130. data/lib/makit/serializer.rb +130 -130
  131. data/lib/makit/services/builder.rb +186 -186
  132. data/lib/makit/services/error_handler.rb +226 -226
  133. data/lib/makit/services/repository_manager.rb +367 -367
  134. data/lib/makit/services/validator.rb +112 -112
  135. data/lib/makit/setup/classlib.rb +101 -101
  136. data/lib/makit/setup/gem.rb +268 -268
  137. data/lib/makit/setup/pages.rb +11 -11
  138. data/lib/makit/setup/razorclasslib.rb +101 -101
  139. data/lib/makit/setup/runner.rb +54 -54
  140. data/lib/makit/setup.rb +5 -5
  141. data/lib/makit/show.rb +110 -110
  142. data/lib/makit/storage.rb +126 -126
  143. data/lib/makit/symbols.rb +175 -175
  144. data/lib/makit/task_info.rb +130 -130
  145. data/lib/makit/tasks/at_exit.rb +15 -15
  146. data/lib/makit/tasks/build.rb +22 -22
  147. data/lib/makit/tasks/bump.rb +7 -7
  148. data/lib/makit/tasks/clean.rb +13 -13
  149. data/lib/makit/tasks/configure.rb +10 -10
  150. data/lib/makit/tasks/format.rb +10 -10
  151. data/lib/makit/tasks/hook_manager.rb +443 -443
  152. data/lib/makit/tasks/info.rb +368 -368
  153. data/lib/makit/tasks/init.rb +49 -49
  154. data/lib/makit/tasks/integrate.rb +60 -60
  155. data/lib/makit/tasks/pull_incoming.rb +13 -13
  156. data/lib/makit/tasks/secrets.rb +7 -7
  157. data/lib/makit/tasks/setup.rb +16 -16
  158. data/lib/makit/tasks/sync.rb +14 -14
  159. data/lib/makit/tasks/tag.rb +27 -27
  160. data/lib/makit/tasks/task_monkey_patch.rb +81 -81
  161. data/lib/makit/tasks/test.rb +22 -22
  162. data/lib/makit/tasks/update.rb +21 -18
  163. data/lib/makit/tasks/version.rb +6 -6
  164. data/lib/makit/tasks.rb +24 -24
  165. data/lib/makit/test_cache.rb +239 -239
  166. data/lib/makit/tree.rb +37 -37
  167. data/lib/makit/v1/configuration/project_service_impl.rb +370 -370
  168. data/lib/makit/v1/git/git_repository_service_impl.rb +295 -295
  169. data/lib/makit/v1/makit.v1_pb.rb +35 -35
  170. data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
  171. data/lib/makit/v1/services/repository_manager_service_impl.rb +572 -572
  172. data/lib/makit/version.rb +661 -661
  173. data/lib/makit/version_util.rb +21 -21
  174. data/lib/makit/wix.rb +95 -95
  175. data/lib/makit/yaml.rb +29 -29
  176. data/lib/makit/zip.rb +17 -17
  177. data/lib/makit/zip_utility.rb +97 -0
  178. data/lib/makit copy.rb +44 -44
  179. data/lib/makit.rb +119 -115
  180. metadata +5 -2
@@ -1,207 +1,207 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative "base"
4
-
5
- module Makit
6
- module Cli
7
- # Commands for managing execution strategies
8
- class StrategyCommands < Base
9
- desc "strategy", "Show current execution strategy information"
10
- option ["--verbose", "-v"], :flag, "Show detailed strategy information"
11
-
12
- def strategy
13
- runner = Makit::Commands::Runner.default
14
- info = runner.strategy_info
15
-
16
- puts "Current Execution Strategy:"
17
- puts " Type: #{info[:type]}"
18
- puts " Class: #{info[:class]}"
19
-
20
- if options[:verbose]
21
- puts "\nFactory Information:"
22
- factory_info = info[:factory_info]
23
- puts " Current: #{factory_info[:current]}"
24
- puts " Available: #{factory_info[:available].join(", ")}"
25
- puts " ChildProcess Available: #{factory_info[:childprocess_available]}"
26
- puts " Open3 Available: #{factory_info[:open3_available]}"
27
- end
28
-
29
- puts "\nEnvironment Variables:"
30
- puts " MAKIT_STRATEGY: #{ENV["MAKIT_STRATEGY"] || "not set (using auto-detect)"}"
31
- end
32
-
33
- desc "strategy test", "Test both strategies and show performance comparison"
34
- option ["--timeout", "-t"], "TIMEOUT", "Timeout for test commands", default: "5"
35
-
36
- def test
37
- timeout = options[:timeout].to_i
38
-
39
- puts "Testing execution strategies..."
40
- puts "=" * 50
41
-
42
- # Test ChildProcess strategy
43
- puts "\n1. Testing ChildProcess Strategy:"
44
- childprocess_result = test_strategy("childprocess", timeout)
45
-
46
- # Test Open3 strategy
47
- puts "\n2. Testing Open3 Strategy:"
48
- open3_result = test_strategy("open3", timeout)
49
-
50
- # Show comparison
51
- puts "\n" + "=" * 50
52
- puts "Performance Comparison:"
53
- puts " ChildProcess: #{childprocess_result[:duration]}s (#{childprocess_result[:status]})"
54
- puts " Open3: #{open3_result[:duration]}s (#{open3_result[:status]})"
55
- end
56
-
57
- private
58
-
59
- # Test a specific strategy
60
- #
61
- # @param strategy_type [String] strategy type to test
62
- # @param timeout [Integer] timeout for test commands
63
- # @return [Hash] test results
64
- def test_strategy(strategy_type, timeout)
65
- start_time = Time.now
66
-
67
- begin
68
- # Create runner with specific strategy
69
- strategy = Makit::Commands::Strategies::Factory.create(strategy: strategy_type)
70
- runner = Makit::Commands::Runner.new(strategy: strategy)
71
-
72
- # Test with a simple command
73
- request = Makit::Commands::Request.new(
74
- command: "echo",
75
- arguments: ["Hello from #{strategy_type}!"],
76
- timeout: timeout,
77
- )
78
-
79
- result = runner.execute(request)
80
- duration = Time.now - start_time
81
-
82
- status = result.success? ? "SUCCESS" : "FAILED"
83
- puts " Status: #{status}"
84
- puts " Duration: #{duration.round(3)}s"
85
- puts " Output: #{result.stdout.strip}"
86
-
87
- if result.failure?
88
- puts " Error: #{result.stderr}"
89
- end
90
-
91
- { duration: duration.round(3), status: status, success: result.success? }
92
- rescue => e
93
- duration = Time.now - start_time
94
- puts " Status: ERROR"
95
- puts " Duration: #{duration.round(3)}s"
96
- puts " Error: #{e.message}"
97
-
98
- { duration: duration.round(3), status: "ERROR", success: false }
99
- end
100
- end
101
- end
102
- end
103
-
104
- # Add trace commands to the main CLI
105
- class TraceCommands < Cli::Base
106
- desc "trace", "Show current trace status and configuration"
107
- option ["--verbose", "-v"], :flag, "Show detailed trace information"
108
-
109
- def trace
110
- puts "Makit Trace Status:"
111
- puts "=" * 30
112
-
113
- status = Makit::Rake.status
114
-
115
- puts "Enhanced Tracing: #{Makit::Rake.tracing_enabled? ? "Enabled" : "Disabled"}"
116
- puts "Rake Trace: #{status[:trace_controller][:rake_trace] || "Not set"}"
117
- puts "Trace Flag: #{status[:trace_controller][:trace_flag] ? "Present" : "Not present"}"
118
- puts "Makit Trace: #{status[:trace_controller][:makit_trace] || "Not set"}"
119
- puts "Verbose Mode: #{status[:verbose] ? "Enabled" : "Disabled"}"
120
-
121
- if options[:verbose]
122
- puts "\nDetailed Information:"
123
- puts " Strategy: #{status[:strategy][:type] || "Unknown"}"
124
- puts " Class: #{status[:strategy][:class] || "Unknown"}"
125
- puts " Factory Info: #{status[:strategy][:factory_info] || "Not available"}"
126
- end
127
- end
128
-
129
- desc "trace enable", "Enable enhanced tracing"
130
-
131
- def enable
132
- ENV["MAKIT_TRACE"] = "true"
133
- puts "Enhanced tracing enabled"
134
- puts "Run 'rake --trace' to see enhanced output"
135
- end
136
-
137
- desc "trace disable", "Disable enhanced tracing"
138
-
139
- def disable
140
- ENV.delete("MAKIT_TRACE")
141
- puts "Enhanced tracing disabled"
142
- end
143
-
144
- desc "trace test", "Test trace functionality with a simple rake task"
145
-
146
- def test
147
- puts "Testing trace functionality..."
148
- puts "Run: rake --trace"
149
- puts "You should see [MAKIT] prefixed trace output for makit-related tasks"
150
- end
151
- end
152
-
153
- # Commands for managing timeout configuration
154
- class TimeoutCommands < Cli::Base
155
- desc "timeout", "Show current timeout configuration"
156
- option ["--verbose", "-v"], :flag, "Show detailed timeout information"
157
-
158
- def timeout
159
- puts "Makit Timeout Configuration:"
160
- puts "=" * 35
161
-
162
- puts "Global Default: #{Makit::Configuration::Timeout.global_default}s"
163
- puts "Environment: #{ENV["MAKIT_DEFAULT_TIMEOUT"] || "Not set"}"
164
-
165
- if options[:verbose]
166
- puts "\nOperation-Specific Timeouts:"
167
- Makit::Configuration::Timeout.all_timeouts.each do |operation, timeout|
168
- puts " #{operation.to_s.ljust(20)}: #{timeout}s"
169
- end
170
- end
171
- end
172
-
173
- desc "timeout set", "Set global default timeout"
174
- option ["--timeout", "-t"], "TIMEOUT", "Timeout in seconds", required: true
175
-
176
- def set
177
- timeout = options[:timeout].to_i
178
- Makit::Configuration::Timeout.validate_timeout(timeout)
179
- ENV["MAKIT_DEFAULT_TIMEOUT"] = timeout.to_s
180
- puts "Global timeout set to #{timeout} seconds"
181
- end
182
-
183
- desc "timeout reset", "Reset timeout to default value"
184
-
185
- def reset
186
- ENV.delete("MAKIT_DEFAULT_TIMEOUT")
187
- puts "Timeout reset to default: #{Makit::Configuration::Timeout.global_default} seconds"
188
- end
189
-
190
- desc "timeout test", "Test timeout configuration with a simple command"
191
- option ["--timeout", "-t"], "TIMEOUT", "Timeout for test command", default: "5"
192
-
193
- def test
194
- timeout = options[:timeout].to_i
195
- puts "Testing timeout configuration with #{timeout}s timeout..."
196
-
197
- # Test with a simple command
198
- result = Makit::Commands::Runner.default.run("echo", "Timeout test", timeout: timeout)
199
-
200
- if result.success?
201
- puts "✓ Timeout test passed"
202
- else
203
- puts "✗ Timeout test failed: #{result.stderr}"
204
- end
205
- end
206
- end
207
- end
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "base"
4
+
5
+ module Makit
6
+ module Cli
7
+ # Commands for managing execution strategies
8
+ class StrategyCommands < Base
9
+ desc "strategy", "Show current execution strategy information"
10
+ option ["--verbose", "-v"], :flag, "Show detailed strategy information"
11
+
12
+ def strategy
13
+ runner = Makit::Commands::Runner.default
14
+ info = runner.strategy_info
15
+
16
+ puts "Current Execution Strategy:"
17
+ puts " Type: #{info[:type]}"
18
+ puts " Class: #{info[:class]}"
19
+
20
+ if options[:verbose]
21
+ puts "\nFactory Information:"
22
+ factory_info = info[:factory_info]
23
+ puts " Current: #{factory_info[:current]}"
24
+ puts " Available: #{factory_info[:available].join(", ")}"
25
+ puts " ChildProcess Available: #{factory_info[:childprocess_available]}"
26
+ puts " Open3 Available: #{factory_info[:open3_available]}"
27
+ end
28
+
29
+ puts "\nEnvironment Variables:"
30
+ puts " MAKIT_STRATEGY: #{ENV["MAKIT_STRATEGY"] || "not set (using auto-detect)"}"
31
+ end
32
+
33
+ desc "strategy test", "Test both strategies and show performance comparison"
34
+ option ["--timeout", "-t"], "TIMEOUT", "Timeout for test commands", default: "5"
35
+
36
+ def test
37
+ timeout = options[:timeout].to_i
38
+
39
+ puts "Testing execution strategies..."
40
+ puts "=" * 50
41
+
42
+ # Test ChildProcess strategy
43
+ puts "\n1. Testing ChildProcess Strategy:"
44
+ childprocess_result = test_strategy("childprocess", timeout)
45
+
46
+ # Test Open3 strategy
47
+ puts "\n2. Testing Open3 Strategy:"
48
+ open3_result = test_strategy("open3", timeout)
49
+
50
+ # Show comparison
51
+ puts "\n" + "=" * 50
52
+ puts "Performance Comparison:"
53
+ puts " ChildProcess: #{childprocess_result[:duration]}s (#{childprocess_result[:status]})"
54
+ puts " Open3: #{open3_result[:duration]}s (#{open3_result[:status]})"
55
+ end
56
+
57
+ private
58
+
59
+ # Test a specific strategy
60
+ #
61
+ # @param strategy_type [String] strategy type to test
62
+ # @param timeout [Integer] timeout for test commands
63
+ # @return [Hash] test results
64
+ def test_strategy(strategy_type, timeout)
65
+ start_time = Time.now
66
+
67
+ begin
68
+ # Create runner with specific strategy
69
+ strategy = Makit::Commands::Strategies::Factory.create(strategy: strategy_type)
70
+ runner = Makit::Commands::Runner.new(strategy: strategy)
71
+
72
+ # Test with a simple command
73
+ request = Makit::Commands::Request.new(
74
+ command: "echo",
75
+ arguments: ["Hello from #{strategy_type}!"],
76
+ timeout: timeout,
77
+ )
78
+
79
+ result = runner.execute(request)
80
+ duration = Time.now - start_time
81
+
82
+ status = result.success? ? "SUCCESS" : "FAILED"
83
+ puts " Status: #{status}"
84
+ puts " Duration: #{duration.round(3)}s"
85
+ puts " Output: #{result.stdout.strip}"
86
+
87
+ if result.failure?
88
+ puts " Error: #{result.stderr}"
89
+ end
90
+
91
+ { duration: duration.round(3), status: status, success: result.success? }
92
+ rescue => e
93
+ duration = Time.now - start_time
94
+ puts " Status: ERROR"
95
+ puts " Duration: #{duration.round(3)}s"
96
+ puts " Error: #{e.message}"
97
+
98
+ { duration: duration.round(3), status: "ERROR", success: false }
99
+ end
100
+ end
101
+ end
102
+ end
103
+
104
+ # Add trace commands to the main CLI
105
+ class TraceCommands < Cli::Base
106
+ desc "trace", "Show current trace status and configuration"
107
+ option ["--verbose", "-v"], :flag, "Show detailed trace information"
108
+
109
+ def trace
110
+ puts "Makit Trace Status:"
111
+ puts "=" * 30
112
+
113
+ status = Makit::Rake.status
114
+
115
+ puts "Enhanced Tracing: #{Makit::Rake.tracing_enabled? ? "Enabled" : "Disabled"}"
116
+ puts "Rake Trace: #{status[:trace_controller][:rake_trace] || "Not set"}"
117
+ puts "Trace Flag: #{status[:trace_controller][:trace_flag] ? "Present" : "Not present"}"
118
+ puts "Makit Trace: #{status[:trace_controller][:makit_trace] || "Not set"}"
119
+ puts "Verbose Mode: #{status[:verbose] ? "Enabled" : "Disabled"}"
120
+
121
+ if options[:verbose]
122
+ puts "\nDetailed Information:"
123
+ puts " Strategy: #{status[:strategy][:type] || "Unknown"}"
124
+ puts " Class: #{status[:strategy][:class] || "Unknown"}"
125
+ puts " Factory Info: #{status[:strategy][:factory_info] || "Not available"}"
126
+ end
127
+ end
128
+
129
+ desc "trace enable", "Enable enhanced tracing"
130
+
131
+ def enable
132
+ ENV["MAKIT_TRACE"] = "true"
133
+ puts "Enhanced tracing enabled"
134
+ puts "Run 'rake --trace' to see enhanced output"
135
+ end
136
+
137
+ desc "trace disable", "Disable enhanced tracing"
138
+
139
+ def disable
140
+ ENV.delete("MAKIT_TRACE")
141
+ puts "Enhanced tracing disabled"
142
+ end
143
+
144
+ desc "trace test", "Test trace functionality with a simple rake task"
145
+
146
+ def test
147
+ puts "Testing trace functionality..."
148
+ puts "Run: rake --trace"
149
+ puts "You should see [MAKIT] prefixed trace output for makit-related tasks"
150
+ end
151
+ end
152
+
153
+ # Commands for managing timeout configuration
154
+ class TimeoutCommands < Cli::Base
155
+ desc "timeout", "Show current timeout configuration"
156
+ option ["--verbose", "-v"], :flag, "Show detailed timeout information"
157
+
158
+ def timeout
159
+ puts "Makit Timeout Configuration:"
160
+ puts "=" * 35
161
+
162
+ puts "Global Default: #{Makit::Configuration::Timeout.global_default}s"
163
+ puts "Environment: #{ENV["MAKIT_DEFAULT_TIMEOUT"] || "Not set"}"
164
+
165
+ if options[:verbose]
166
+ puts "\nOperation-Specific Timeouts:"
167
+ Makit::Configuration::Timeout.all_timeouts.each do |operation, timeout|
168
+ puts " #{operation.to_s.ljust(20)}: #{timeout}s"
169
+ end
170
+ end
171
+ end
172
+
173
+ desc "timeout set", "Set global default timeout"
174
+ option ["--timeout", "-t"], "TIMEOUT", "Timeout in seconds", required: true
175
+
176
+ def set
177
+ timeout = options[:timeout].to_i
178
+ Makit::Configuration::Timeout.validate_timeout(timeout)
179
+ ENV["MAKIT_DEFAULT_TIMEOUT"] = timeout.to_s
180
+ puts "Global timeout set to #{timeout} seconds"
181
+ end
182
+
183
+ desc "timeout reset", "Reset timeout to default value"
184
+
185
+ def reset
186
+ ENV.delete("MAKIT_DEFAULT_TIMEOUT")
187
+ puts "Timeout reset to default: #{Makit::Configuration::Timeout.global_default} seconds"
188
+ end
189
+
190
+ desc "timeout test", "Test timeout configuration with a simple command"
191
+ option ["--timeout", "-t"], "TIMEOUT", "Timeout for test command", default: "5"
192
+
193
+ def test
194
+ timeout = options[:timeout].to_i
195
+ puts "Testing timeout configuration with #{timeout}s timeout..."
196
+
197
+ # Test with a simple command
198
+ result = Makit::Commands::Runner.default.run("echo", "Timeout test", timeout: timeout)
199
+
200
+ if result.success?
201
+ puts "✓ Timeout test passed"
202
+ else
203
+ puts "✗ Timeout test failed: #{result.stderr}"
204
+ end
205
+ end
206
+ end
207
+ end