makit 0.0.143 → 0.0.144

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 (154) 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/cli/build_commands.rb +500 -500
  7. data/lib/makit/cli/generators/base_generator.rb +74 -74
  8. data/lib/makit/cli/generators/dotnet_generator.rb +50 -50
  9. data/lib/makit/cli/generators/generator_factory.rb +49 -49
  10. data/lib/makit/cli/generators/node_generator.rb +50 -50
  11. data/lib/makit/cli/generators/ruby_generator.rb +77 -77
  12. data/lib/makit/cli/generators/rust_generator.rb +50 -50
  13. data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -167
  14. data/lib/makit/cli/generators/templates/node_templates.rb +161 -161
  15. data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -26
  16. data/lib/makit/cli/generators/templates/ruby/gemspec.rb +40 -40
  17. data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -33
  18. data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -35
  19. data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -63
  20. data/lib/makit/cli/generators/templates/ruby/test.rb +39 -39
  21. data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -29
  22. data/lib/makit/cli/generators/templates/ruby/version.rb +29 -29
  23. data/lib/makit/cli/generators/templates/rust_templates.rb +128 -128
  24. data/lib/makit/cli/main.rb +69 -69
  25. data/lib/makit/cli/project_commands.rb +868 -868
  26. data/lib/makit/cli/repository_commands.rb +661 -661
  27. data/lib/makit/cli/strategy_commands.rb +212 -212
  28. data/lib/makit/cli/utility_commands.rb +521 -521
  29. data/lib/makit/commands/factory.rb +359 -359
  30. data/lib/makit/commands/middleware/base.rb +73 -73
  31. data/lib/makit/commands/middleware/cache.rb +248 -248
  32. data/lib/makit/commands/middleware/command_logger.rb +312 -312
  33. data/lib/makit/commands/middleware/validator.rb +269 -269
  34. data/lib/makit/commands/request.rb +316 -316
  35. data/lib/makit/commands/result.rb +323 -323
  36. data/lib/makit/commands/runner.rb +386 -386
  37. data/lib/makit/commands/strategies/base.rb +171 -171
  38. data/lib/makit/commands/strategies/child_process.rb +162 -162
  39. data/lib/makit/commands/strategies/factory.rb +136 -136
  40. data/lib/makit/commands/strategies/synchronous.rb +139 -139
  41. data/lib/makit/commands.rb +50 -50
  42. data/lib/makit/configuration/dotnet_project.rb +48 -39
  43. data/lib/makit/configuration/gitlab_helper.rb +58 -58
  44. data/lib/makit/configuration/project.rb +168 -168
  45. data/lib/makit/configuration/rakefile_helper.rb +43 -43
  46. data/lib/makit/configuration/step.rb +34 -34
  47. data/lib/makit/configuration/timeout.rb +74 -74
  48. data/lib/makit/configuration.rb +16 -16
  49. data/lib/makit/content/default_gitignore.rb +7 -7
  50. data/lib/makit/content/default_gitignore.txt +225 -225
  51. data/lib/makit/content/default_rakefile.rb +13 -13
  52. data/lib/makit/content/gem_rakefile.rb +16 -16
  53. data/lib/makit/context.rb +1 -1
  54. data/lib/makit/data.rb +49 -49
  55. data/lib/makit/directories.rb +140 -140
  56. data/lib/makit/directory.rb +262 -262
  57. data/lib/makit/docs/files.rb +89 -89
  58. data/lib/makit/docs/rake.rb +102 -102
  59. data/lib/makit/dotnet/cli.rb +69 -69
  60. data/lib/makit/dotnet/project.rb +217 -217
  61. data/lib/makit/dotnet/solution.rb +38 -38
  62. data/lib/makit/dotnet/solution_classlib.rb +239 -239
  63. data/lib/makit/dotnet/solution_console.rb +264 -264
  64. data/lib/makit/dotnet/solution_maui.rb +354 -354
  65. data/lib/makit/dotnet/solution_wasm.rb +275 -275
  66. data/lib/makit/dotnet/solution_wpf.rb +304 -304
  67. data/lib/makit/dotnet.rb +102 -102
  68. data/lib/makit/email.rb +90 -90
  69. data/lib/makit/environment.rb +142 -142
  70. data/lib/makit/examples/runner.rb +370 -370
  71. data/lib/makit/exceptions.rb +45 -45
  72. data/lib/makit/fileinfo.rb +24 -24
  73. data/lib/makit/files.rb +43 -43
  74. data/lib/makit/gems.rb +40 -40
  75. data/lib/makit/git/cli.rb +54 -54
  76. data/lib/makit/git/repository.rb +90 -90
  77. data/lib/makit/git.rb +98 -98
  78. data/lib/makit/gitlab_runner.rb +59 -59
  79. data/lib/makit/humanize.rb +137 -137
  80. data/lib/makit/indexer.rb +47 -47
  81. data/lib/makit/logging/configuration.rb +308 -308
  82. data/lib/makit/logging/format_registry.rb +84 -84
  83. data/lib/makit/logging/formatters/base.rb +39 -39
  84. data/lib/makit/logging/formatters/console_formatter.rb +140 -140
  85. data/lib/makit/logging/formatters/json_formatter.rb +65 -65
  86. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
  87. data/lib/makit/logging/formatters/text_formatter.rb +64 -64
  88. data/lib/makit/logging/log_request.rb +119 -119
  89. data/lib/makit/logging/logger.rb +199 -199
  90. data/lib/makit/logging/sinks/base.rb +91 -91
  91. data/lib/makit/logging/sinks/console.rb +72 -72
  92. data/lib/makit/logging/sinks/file_sink.rb +92 -92
  93. data/lib/makit/logging/sinks/structured.rb +123 -123
  94. data/lib/makit/logging/sinks/unified_file_sink.rb +296 -296
  95. data/lib/makit/logging.rb +565 -565
  96. data/lib/makit/markdown.rb +75 -75
  97. data/lib/makit/mp/basic_object_mp.rb +17 -17
  98. data/lib/makit/mp/command_mp.rb +13 -13
  99. data/lib/makit/mp/command_request.mp.rb +17 -17
  100. data/lib/makit/mp/project_mp.rb +199 -199
  101. data/lib/makit/mp/string_mp.rb +199 -199
  102. data/lib/makit/nuget.rb +74 -74
  103. data/lib/makit/port.rb +32 -32
  104. data/lib/makit/process.rb +377 -163
  105. data/lib/makit/protoc.rb +107 -107
  106. data/lib/makit/rake/cli.rb +196 -196
  107. data/lib/makit/rake/trace_controller.rb +174 -174
  108. data/lib/makit/rake.rb +81 -81
  109. data/lib/makit/ruby/cli.rb +185 -185
  110. data/lib/makit/ruby.rb +25 -25
  111. data/lib/makit/secrets.rb +51 -51
  112. data/lib/makit/serializer.rb +130 -130
  113. data/lib/makit/services/builder.rb +186 -186
  114. data/lib/makit/services/error_handler.rb +226 -226
  115. data/lib/makit/services/repository_manager.rb +231 -231
  116. data/lib/makit/services/validator.rb +112 -112
  117. data/lib/makit/setup/classlib.rb +101 -101
  118. data/lib/makit/setup/gem.rb +268 -268
  119. data/lib/makit/setup/pages.rb +11 -11
  120. data/lib/makit/setup/razorclasslib.rb +101 -101
  121. data/lib/makit/setup/runner.rb +54 -54
  122. data/lib/makit/setup.rb +5 -5
  123. data/lib/makit/show.rb +110 -110
  124. data/lib/makit/storage.rb +126 -126
  125. data/lib/makit/symbols.rb +170 -170
  126. data/lib/makit/task_info.rb +130 -130
  127. data/lib/makit/tasks/at_exit.rb +15 -15
  128. data/lib/makit/tasks/build.rb +22 -22
  129. data/lib/makit/tasks/clean.rb +13 -13
  130. data/lib/makit/tasks/configure.rb +10 -10
  131. data/lib/makit/tasks/format.rb +10 -10
  132. data/lib/makit/tasks/hook_manager.rb +443 -443
  133. data/lib/makit/tasks/init.rb +49 -49
  134. data/lib/makit/tasks/integrate.rb +29 -29
  135. data/lib/makit/tasks/pull_incoming.rb +13 -13
  136. data/lib/makit/tasks/setup.rb +16 -16
  137. data/lib/makit/tasks/sync.rb +17 -17
  138. data/lib/makit/tasks/tag.rb +16 -16
  139. data/lib/makit/tasks/task_monkey_patch.rb +81 -81
  140. data/lib/makit/tasks/test.rb +22 -22
  141. data/lib/makit/tasks/update.rb +18 -18
  142. data/lib/makit/tasks.rb +20 -20
  143. data/lib/makit/test_cache.rb +239 -239
  144. data/lib/makit/tree.rb +37 -37
  145. data/lib/makit/v1/makit.v1_pb.rb +35 -35
  146. data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
  147. data/lib/makit/version.rb +100 -100
  148. data/lib/makit/version_util.rb +21 -21
  149. data/lib/makit/wix.rb +95 -95
  150. data/lib/makit/yaml.rb +29 -29
  151. data/lib/makit/zip.rb +17 -17
  152. data/lib/makit copy.rb +44 -44
  153. data/lib/makit.rb +43 -43
  154. metadata +2 -2
@@ -1,212 +1,212 @@
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
- module Makit
106
- module Cli
107
- # Commands for managing trace functionality
108
- class TraceCommands < Base
109
- desc "trace", "Show current trace status and configuration"
110
- option ["--verbose", "-v"], :flag, "Show detailed trace information"
111
-
112
- def trace
113
- puts "Makit Trace Status:"
114
- puts "=" * 30
115
-
116
- status = Makit::Rake.status
117
-
118
- puts "Enhanced Tracing: #{Makit::Rake.tracing_enabled? ? "Enabled" : "Disabled"}"
119
- puts "Rake Trace: #{status[:trace_controller][:rake_trace] || "Not set"}"
120
- puts "Trace Flag: #{status[:trace_controller][:trace_flag] ? "Present" : "Not present"}"
121
- puts "Makit Trace: #{status[:trace_controller][:makit_trace] || "Not set"}"
122
- puts "Verbose Mode: #{status[:verbose] ? "Enabled" : "Disabled"}"
123
-
124
- if options[:verbose]
125
- puts "\nDetailed Information:"
126
- puts " Strategy: #{status[:strategy][:type] || "Unknown"}"
127
- puts " Class: #{status[:strategy][:class] || "Unknown"}"
128
- puts " Factory Info: #{status[:strategy][:factory_info] || "Not available"}"
129
- end
130
- end
131
-
132
- desc "trace enable", "Enable enhanced tracing"
133
-
134
- def enable
135
- ENV["MAKIT_TRACE"] = "true"
136
- puts "Enhanced tracing enabled"
137
- puts "Run 'rake --trace' to see enhanced output"
138
- end
139
-
140
- desc "trace disable", "Disable enhanced tracing"
141
-
142
- def disable
143
- ENV.delete("MAKIT_TRACE")
144
- puts "Enhanced tracing disabled"
145
- end
146
-
147
- desc "trace test", "Test trace functionality with a simple rake task"
148
-
149
- def test
150
- puts "Testing trace functionality..."
151
- puts "Run: rake --trace"
152
- puts "You should see [MAKIT] prefixed trace output for makit-related tasks"
153
- end
154
- end
155
-
156
- # Commands for managing timeout configuration
157
- class TimeoutCommands < Base
158
- desc "timeout", "Show current timeout configuration"
159
- option ["--verbose", "-v"], :flag, "Show detailed timeout information"
160
-
161
- def timeout
162
- puts "Makit Timeout Configuration:"
163
- puts "=" * 35
164
-
165
- puts "Global Default: #{Makit::Configuration::Timeout.global_default}s"
166
- puts "Environment: #{ENV["MAKIT_DEFAULT_TIMEOUT"] || "Not set"}"
167
-
168
- if options[:verbose]
169
- puts "\nOperation-Specific Timeouts:"
170
- Makit::Configuration::Timeout.all_timeouts.each do |operation, timeout|
171
- puts " #{operation.to_s.ljust(20)}: #{timeout}s"
172
- end
173
- end
174
- end
175
-
176
- desc "timeout set", "Set global default timeout"
177
- option ["--timeout", "-t"], "TIMEOUT", "Timeout in seconds", required: true
178
-
179
- def set
180
- timeout = options[:timeout].to_i
181
- Makit::Configuration::Timeout.validate_timeout(timeout)
182
- ENV["MAKIT_DEFAULT_TIMEOUT"] = timeout.to_s
183
- puts "Global timeout set to #{timeout} seconds"
184
- end
185
-
186
- desc "timeout reset", "Reset timeout to default value"
187
-
188
- def reset
189
- ENV.delete("MAKIT_DEFAULT_TIMEOUT")
190
- puts "Timeout reset to default: #{Makit::Configuration::Timeout.global_default} seconds"
191
- end
192
-
193
- desc "timeout test", "Test timeout configuration with a simple command"
194
- option ["--timeout", "-t"], "TIMEOUT", "Timeout for test command", default: "5"
195
-
196
- def test
197
- timeout = options[:timeout].to_i
198
- puts "Testing timeout configuration with #{timeout}s timeout..."
199
-
200
- # Test with a simple command
201
- result = Makit::Commands::Runner.default.run("echo", "Timeout test", timeout: timeout)
202
-
203
- if result.success?
204
- puts "✓ Timeout test passed"
205
- else
206
- puts "✗ Timeout test failed: #{result.stderr}"
207
- end
208
- end
209
- end
210
- end
211
- end
212
- 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
+ module Makit
106
+ module Cli
107
+ # Commands for managing trace functionality
108
+ class TraceCommands < Base
109
+ desc "trace", "Show current trace status and configuration"
110
+ option ["--verbose", "-v"], :flag, "Show detailed trace information"
111
+
112
+ def trace
113
+ puts "Makit Trace Status:"
114
+ puts "=" * 30
115
+
116
+ status = Makit::Rake.status
117
+
118
+ puts "Enhanced Tracing: #{Makit::Rake.tracing_enabled? ? "Enabled" : "Disabled"}"
119
+ puts "Rake Trace: #{status[:trace_controller][:rake_trace] || "Not set"}"
120
+ puts "Trace Flag: #{status[:trace_controller][:trace_flag] ? "Present" : "Not present"}"
121
+ puts "Makit Trace: #{status[:trace_controller][:makit_trace] || "Not set"}"
122
+ puts "Verbose Mode: #{status[:verbose] ? "Enabled" : "Disabled"}"
123
+
124
+ if options[:verbose]
125
+ puts "\nDetailed Information:"
126
+ puts " Strategy: #{status[:strategy][:type] || "Unknown"}"
127
+ puts " Class: #{status[:strategy][:class] || "Unknown"}"
128
+ puts " Factory Info: #{status[:strategy][:factory_info] || "Not available"}"
129
+ end
130
+ end
131
+
132
+ desc "trace enable", "Enable enhanced tracing"
133
+
134
+ def enable
135
+ ENV["MAKIT_TRACE"] = "true"
136
+ puts "Enhanced tracing enabled"
137
+ puts "Run 'rake --trace' to see enhanced output"
138
+ end
139
+
140
+ desc "trace disable", "Disable enhanced tracing"
141
+
142
+ def disable
143
+ ENV.delete("MAKIT_TRACE")
144
+ puts "Enhanced tracing disabled"
145
+ end
146
+
147
+ desc "trace test", "Test trace functionality with a simple rake task"
148
+
149
+ def test
150
+ puts "Testing trace functionality..."
151
+ puts "Run: rake --trace"
152
+ puts "You should see [MAKIT] prefixed trace output for makit-related tasks"
153
+ end
154
+ end
155
+
156
+ # Commands for managing timeout configuration
157
+ class TimeoutCommands < Base
158
+ desc "timeout", "Show current timeout configuration"
159
+ option ["--verbose", "-v"], :flag, "Show detailed timeout information"
160
+
161
+ def timeout
162
+ puts "Makit Timeout Configuration:"
163
+ puts "=" * 35
164
+
165
+ puts "Global Default: #{Makit::Configuration::Timeout.global_default}s"
166
+ puts "Environment: #{ENV["MAKIT_DEFAULT_TIMEOUT"] || "Not set"}"
167
+
168
+ if options[:verbose]
169
+ puts "\nOperation-Specific Timeouts:"
170
+ Makit::Configuration::Timeout.all_timeouts.each do |operation, timeout|
171
+ puts " #{operation.to_s.ljust(20)}: #{timeout}s"
172
+ end
173
+ end
174
+ end
175
+
176
+ desc "timeout set", "Set global default timeout"
177
+ option ["--timeout", "-t"], "TIMEOUT", "Timeout in seconds", required: true
178
+
179
+ def set
180
+ timeout = options[:timeout].to_i
181
+ Makit::Configuration::Timeout.validate_timeout(timeout)
182
+ ENV["MAKIT_DEFAULT_TIMEOUT"] = timeout.to_s
183
+ puts "Global timeout set to #{timeout} seconds"
184
+ end
185
+
186
+ desc "timeout reset", "Reset timeout to default value"
187
+
188
+ def reset
189
+ ENV.delete("MAKIT_DEFAULT_TIMEOUT")
190
+ puts "Timeout reset to default: #{Makit::Configuration::Timeout.global_default} seconds"
191
+ end
192
+
193
+ desc "timeout test", "Test timeout configuration with a simple command"
194
+ option ["--timeout", "-t"], "TIMEOUT", "Timeout for test command", default: "5"
195
+
196
+ def test
197
+ timeout = options[:timeout].to_i
198
+ puts "Testing timeout configuration with #{timeout}s timeout..."
199
+
200
+ # Test with a simple command
201
+ result = Makit::Commands::Runner.default.run("echo", "Timeout test", timeout: timeout)
202
+
203
+ if result.success?
204
+ puts "✓ Timeout test passed"
205
+ else
206
+ puts "✗ Timeout test failed: #{result.stderr}"
207
+ end
208
+ end
209
+ end
210
+ end
211
+ end
212
+ end