makit 0.0.138 → 0.0.140

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 (151) 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 -67
  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 +51 -0
  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 +385 -385
  37. data/lib/makit/commands/strategies/base.rb +171 -171
  38. data/lib/makit/commands/strategies/child_process.rb +1 -1
  39. data/lib/makit/commands/strategies/synchronous.rb +139 -139
  40. data/lib/makit/commands.rb +50 -50
  41. data/lib/makit/configuration/dotnet_project.rb +12 -12
  42. data/lib/makit/configuration/gitlab_helper.rb +58 -58
  43. data/lib/makit/configuration/project.rb +168 -168
  44. data/lib/makit/configuration/rakefile_helper.rb +43 -43
  45. data/lib/makit/configuration/step.rb +34 -34
  46. data/lib/makit/configuration/timeout.rb +74 -0
  47. data/lib/makit/configuration.rb +15 -14
  48. data/lib/makit/content/default_gitignore.rb +7 -7
  49. data/lib/makit/content/default_gitignore.txt +225 -225
  50. data/lib/makit/content/default_rakefile.rb +13 -13
  51. data/lib/makit/content/gem_rakefile.rb +16 -16
  52. data/lib/makit/context.rb +1 -1
  53. data/lib/makit/data.rb +49 -49
  54. data/lib/makit/directories.rb +140 -140
  55. data/lib/makit/directory.rb +262 -262
  56. data/lib/makit/docs/files.rb +89 -89
  57. data/lib/makit/docs/rake.rb +102 -102
  58. data/lib/makit/dotnet/cli.rb +69 -69
  59. data/lib/makit/dotnet/project.rb +217 -217
  60. data/lib/makit/dotnet/solution.rb +38 -38
  61. data/lib/makit/dotnet/solution_classlib.rb +239 -239
  62. data/lib/makit/dotnet/solution_console.rb +264 -264
  63. data/lib/makit/dotnet/solution_maui.rb +354 -354
  64. data/lib/makit/dotnet/solution_wasm.rb +275 -275
  65. data/lib/makit/dotnet/solution_wpf.rb +304 -304
  66. data/lib/makit/dotnet.rb +102 -102
  67. data/lib/makit/email.rb +90 -90
  68. data/lib/makit/environment.rb +142 -142
  69. data/lib/makit/examples/runner.rb +370 -370
  70. data/lib/makit/exceptions.rb +45 -45
  71. data/lib/makit/fileinfo.rb +24 -24
  72. data/lib/makit/files.rb +43 -43
  73. data/lib/makit/gems.rb +40 -40
  74. data/lib/makit/git/cli.rb +54 -54
  75. data/lib/makit/git/repository.rb +90 -90
  76. data/lib/makit/git.rb +98 -98
  77. data/lib/makit/gitlab_runner.rb +59 -59
  78. data/lib/makit/humanize.rb +137 -137
  79. data/lib/makit/indexer.rb +47 -47
  80. data/lib/makit/logging/configuration.rb +308 -308
  81. data/lib/makit/logging/format_registry.rb +84 -84
  82. data/lib/makit/logging/formatters/base.rb +39 -39
  83. data/lib/makit/logging/formatters/console_formatter.rb +140 -140
  84. data/lib/makit/logging/formatters/json_formatter.rb +65 -65
  85. data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
  86. data/lib/makit/logging/formatters/text_formatter.rb +64 -64
  87. data/lib/makit/logging/log_request.rb +119 -119
  88. data/lib/makit/logging/logger.rb +199 -199
  89. data/lib/makit/logging/sinks/base.rb +91 -91
  90. data/lib/makit/logging/sinks/console.rb +72 -72
  91. data/lib/makit/logging/sinks/file_sink.rb +92 -92
  92. data/lib/makit/logging/sinks/structured.rb +123 -123
  93. data/lib/makit/logging/sinks/unified_file_sink.rb +296 -296
  94. data/lib/makit/logging.rb +565 -565
  95. data/lib/makit/markdown.rb +75 -75
  96. data/lib/makit/mp/basic_object_mp.rb +17 -17
  97. data/lib/makit/mp/command_mp.rb +13 -13
  98. data/lib/makit/mp/command_request.mp.rb +17 -17
  99. data/lib/makit/mp/project_mp.rb +199 -199
  100. data/lib/makit/mp/string_mp.rb +191 -191
  101. data/lib/makit/nuget.rb +74 -74
  102. data/lib/makit/port.rb +32 -32
  103. data/lib/makit/process.rb +163 -163
  104. data/lib/makit/protoc.rb +107 -107
  105. data/lib/makit/rake/cli.rb +196 -196
  106. data/lib/makit/rake.rb +80 -80
  107. data/lib/makit/ruby/cli.rb +185 -185
  108. data/lib/makit/ruby.rb +25 -25
  109. data/lib/makit/secrets.rb +51 -51
  110. data/lib/makit/serializer.rb +130 -130
  111. data/lib/makit/services/builder.rb +186 -186
  112. data/lib/makit/services/error_handler.rb +226 -226
  113. data/lib/makit/services/repository_manager.rb +231 -231
  114. data/lib/makit/services/validator.rb +112 -112
  115. data/lib/makit/setup/classlib.rb +101 -101
  116. data/lib/makit/setup/gem.rb +268 -268
  117. data/lib/makit/setup/razorclasslib.rb +101 -101
  118. data/lib/makit/setup/runner.rb +54 -54
  119. data/lib/makit/setup.rb +5 -5
  120. data/lib/makit/show.rb +110 -110
  121. data/lib/makit/storage.rb +126 -126
  122. data/lib/makit/symbols.rb +170 -170
  123. data/lib/makit/task_info.rb +130 -130
  124. data/lib/makit/tasks/at_exit.rb +15 -15
  125. data/lib/makit/tasks/build.rb +22 -22
  126. data/lib/makit/tasks/clean.rb +13 -13
  127. data/lib/makit/tasks/configure.rb +10 -10
  128. data/lib/makit/tasks/format.rb +10 -10
  129. data/lib/makit/tasks/hook_manager.rb +443 -443
  130. data/lib/makit/tasks/init.rb +49 -49
  131. data/lib/makit/tasks/integrate.rb +29 -29
  132. data/lib/makit/tasks/pull_incoming.rb +13 -13
  133. data/lib/makit/tasks/setup.rb +13 -13
  134. data/lib/makit/tasks/sync.rb +17 -17
  135. data/lib/makit/tasks/tag.rb +16 -16
  136. data/lib/makit/tasks/task_monkey_patch.rb +81 -81
  137. data/lib/makit/tasks/test.rb +22 -22
  138. data/lib/makit/tasks/update.rb +18 -18
  139. data/lib/makit/tasks.rb +20 -20
  140. data/lib/makit/test_cache.rb +239 -239
  141. data/lib/makit/tree.rb +37 -37
  142. data/lib/makit/v1/makit.v1_pb.rb +35 -35
  143. data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
  144. data/lib/makit/version.rb +99 -99
  145. data/lib/makit/version_util.rb +21 -21
  146. data/lib/makit/wix.rb +95 -95
  147. data/lib/makit/yaml.rb +29 -29
  148. data/lib/makit/zip.rb +17 -17
  149. data/lib/makit copy.rb +44 -44
  150. data/lib/makit.rb +42 -42
  151. metadata +3 -2
@@ -1,112 +1,112 @@
1
- # frozen_string_literal: true
2
-
3
- module Makit
4
- module Services
5
- # Service class responsible for validating all input parameters
6
- # Used by various Makit operations to ensure data integrity
7
- class Validator
8
- # Git-related validation constants
9
- COMMIT_HASH_LENGTH = 40
10
- COMMIT_LATEST = "latest"
11
- MAX_PAGINATION_LIMIT = 1000
12
- MAX_DIRECTORY_PATH_LENGTH = 255
13
-
14
- class << self
15
- # Validate directory parameter for initialization operations
16
- #
17
- # @param directory [String] the directory path to validate
18
- # @raise [ArgumentError] if directory parameter is invalid
19
- def validate_directory_parameter(directory)
20
- raise ArgumentError, "directory parameter cannot be nil" if directory.nil?
21
- raise ArgumentError, "directory parameter cannot be empty" if directory.to_s.strip.empty?
22
- raise ArgumentError, "directory path contains invalid characters" if directory.to_s.include?("\0")
23
- raise ArgumentError, "directory path is too long" if directory.to_s.length > MAX_DIRECTORY_PATH_LENGTH
24
- end
25
-
26
- # Validate URL parameter for git repository operations
27
- #
28
- # @param url [String] the repository URL to validate
29
- # @raise [ArgumentError] if URL parameter is invalid
30
- def validate_url_parameter(url)
31
- raise ArgumentError, "URL parameter cannot be nil" if url.nil?
32
- raise ArgumentError, "URL parameter cannot be empty" if url.to_s.strip.empty?
33
-
34
- url_str = url.to_s.strip
35
- # Basic URL format validation - accept git@, https://, http://, and simple names like "user/repo"
36
- valid_patterns = [
37
- %r{\Agit@[\w.-]+:[\w._/-]+\.git\z}, # SSH format: git@github.com:user/repo.git
38
- %r{\Ahttps?://[\w.-]+/[\w._/-]+(\.git)?\z}, # HTTPS format: https://github.com/user/repo
39
- %r{\A[\w.-]+/[\w._-]+\z}, # Simple format: user/repo
40
- ]
41
-
42
- return if valid_patterns.any? { |pattern| url_str.match?(pattern) }
43
-
44
- raise ArgumentError, "Invalid URL format: #{url_str}"
45
- end
46
-
47
- # Validate commit parameter for git operations
48
- #
49
- # @param commit [String] the commit hash or "latest" to validate
50
- # @raise [ArgumentError] if commit parameter is invalid
51
- def validate_commit_parameter(commit)
52
- raise ArgumentError, "commit parameter cannot be nil" if commit.nil?
53
-
54
- commit_str = commit.to_s.strip
55
- raise ArgumentError, "commit parameter cannot be empty" if commit_str.empty?
56
-
57
- # Allow "latest" or valid commit hash formats
58
- return if commit_str == COMMIT_LATEST
59
- return if commit_str.match?(/\A[0-9a-f]{7,#{COMMIT_HASH_LENGTH}}\z/i)
60
-
61
- raise ArgumentError, "Invalid commit format: #{commit_str}. Must be 'latest' or a valid git commit hash."
62
- end
63
-
64
- # Validate pagination parameters for log operations
65
- #
66
- # @param limit [Integer] maximum number of items to retrieve
67
- # @param skip [Integer] number of items to skip
68
- # @raise [ArgumentError] if pagination parameters are invalid
69
- def validate_pagination_parameters(limit, skip)
70
- unless limit.is_a?(Integer) && limit.positive?
71
- raise ArgumentError,
72
- "limit parameter must be a positive integer"
73
- end
74
- raise ArgumentError, "skip parameter must be a non-negative integer" unless skip.is_a?(Integer) && skip >= 0
75
- raise ArgumentError, "limit parameter is too large" if limit > MAX_PAGINATION_LIMIT
76
- end
77
-
78
- # Validate that a directory exists and is accessible
79
- #
80
- # @param directory [String] the directory path to check
81
- # @param description [String] human-readable description for error messages
82
- # @raise [Makit::DirectoryError] if directory doesn't exist or isn't accessible
83
- def validate_directory_exists(directory, description = "directory")
84
- return if Dir.exist?(directory)
85
-
86
- raise Makit::DirectoryError, "#{description} does not exist: #{directory}"
87
- end
88
-
89
- # Validate boolean parameters
90
- #
91
- # @param value [Object] the value to check
92
- # @param parameter_name [String] the parameter name for error messages
93
- # @raise [ArgumentError] if value is not boolean
94
- def validate_boolean_parameter(value, parameter_name)
95
- return if [true, false].include?(value)
96
-
97
- raise ArgumentError, "#{parameter_name} must be true or false, got #{value.class}"
98
- end
99
-
100
- # Validate string parameters that cannot be empty
101
- #
102
- # @param value [String] the string value to validate
103
- # @param parameter_name [String] the parameter name for error messages
104
- # @raise [ArgumentError] if string is nil or empty
105
- def validate_required_string(value, parameter_name)
106
- raise ArgumentError, "#{parameter_name} cannot be nil" if value.nil?
107
- raise ArgumentError, "#{parameter_name} cannot be empty" if value.to_s.strip.empty?
108
- end
109
- end
110
- end
111
- end
112
- end
1
+ # frozen_string_literal: true
2
+
3
+ module Makit
4
+ module Services
5
+ # Service class responsible for validating all input parameters
6
+ # Used by various Makit operations to ensure data integrity
7
+ class Validator
8
+ # Git-related validation constants
9
+ COMMIT_HASH_LENGTH = 40
10
+ COMMIT_LATEST = "latest"
11
+ MAX_PAGINATION_LIMIT = 1000
12
+ MAX_DIRECTORY_PATH_LENGTH = 255
13
+
14
+ class << self
15
+ # Validate directory parameter for initialization operations
16
+ #
17
+ # @param directory [String] the directory path to validate
18
+ # @raise [ArgumentError] if directory parameter is invalid
19
+ def validate_directory_parameter(directory)
20
+ raise ArgumentError, "directory parameter cannot be nil" if directory.nil?
21
+ raise ArgumentError, "directory parameter cannot be empty" if directory.to_s.strip.empty?
22
+ raise ArgumentError, "directory path contains invalid characters" if directory.to_s.include?("\0")
23
+ raise ArgumentError, "directory path is too long" if directory.to_s.length > MAX_DIRECTORY_PATH_LENGTH
24
+ end
25
+
26
+ # Validate URL parameter for git repository operations
27
+ #
28
+ # @param url [String] the repository URL to validate
29
+ # @raise [ArgumentError] if URL parameter is invalid
30
+ def validate_url_parameter(url)
31
+ raise ArgumentError, "URL parameter cannot be nil" if url.nil?
32
+ raise ArgumentError, "URL parameter cannot be empty" if url.to_s.strip.empty?
33
+
34
+ url_str = url.to_s.strip
35
+ # Basic URL format validation - accept git@, https://, http://, and simple names like "user/repo"
36
+ valid_patterns = [
37
+ %r{\Agit@[\w.-]+:[\w._/-]+\.git\z}, # SSH format: git@github.com:user/repo.git
38
+ %r{\Ahttps?://[\w.-]+/[\w._/-]+(\.git)?\z}, # HTTPS format: https://github.com/user/repo
39
+ %r{\A[\w.-]+/[\w._-]+\z}, # Simple format: user/repo
40
+ ]
41
+
42
+ return if valid_patterns.any? { |pattern| url_str.match?(pattern) }
43
+
44
+ raise ArgumentError, "Invalid URL format: #{url_str}"
45
+ end
46
+
47
+ # Validate commit parameter for git operations
48
+ #
49
+ # @param commit [String] the commit hash or "latest" to validate
50
+ # @raise [ArgumentError] if commit parameter is invalid
51
+ def validate_commit_parameter(commit)
52
+ raise ArgumentError, "commit parameter cannot be nil" if commit.nil?
53
+
54
+ commit_str = commit.to_s.strip
55
+ raise ArgumentError, "commit parameter cannot be empty" if commit_str.empty?
56
+
57
+ # Allow "latest" or valid commit hash formats
58
+ return if commit_str == COMMIT_LATEST
59
+ return if commit_str.match?(/\A[0-9a-f]{7,#{COMMIT_HASH_LENGTH}}\z/i)
60
+
61
+ raise ArgumentError, "Invalid commit format: #{commit_str}. Must be 'latest' or a valid git commit hash."
62
+ end
63
+
64
+ # Validate pagination parameters for log operations
65
+ #
66
+ # @param limit [Integer] maximum number of items to retrieve
67
+ # @param skip [Integer] number of items to skip
68
+ # @raise [ArgumentError] if pagination parameters are invalid
69
+ def validate_pagination_parameters(limit, skip)
70
+ unless limit.is_a?(Integer) && limit.positive?
71
+ raise ArgumentError,
72
+ "limit parameter must be a positive integer"
73
+ end
74
+ raise ArgumentError, "skip parameter must be a non-negative integer" unless skip.is_a?(Integer) && skip >= 0
75
+ raise ArgumentError, "limit parameter is too large" if limit > MAX_PAGINATION_LIMIT
76
+ end
77
+
78
+ # Validate that a directory exists and is accessible
79
+ #
80
+ # @param directory [String] the directory path to check
81
+ # @param description [String] human-readable description for error messages
82
+ # @raise [Makit::DirectoryError] if directory doesn't exist or isn't accessible
83
+ def validate_directory_exists(directory, description = "directory")
84
+ return if Dir.exist?(directory)
85
+
86
+ raise Makit::DirectoryError, "#{description} does not exist: #{directory}"
87
+ end
88
+
89
+ # Validate boolean parameters
90
+ #
91
+ # @param value [Object] the value to check
92
+ # @param parameter_name [String] the parameter name for error messages
93
+ # @raise [ArgumentError] if value is not boolean
94
+ def validate_boolean_parameter(value, parameter_name)
95
+ return if [true, false].include?(value)
96
+
97
+ raise ArgumentError, "#{parameter_name} must be true or false, got #{value.class}"
98
+ end
99
+
100
+ # Validate string parameters that cannot be empty
101
+ #
102
+ # @param value [String] the string value to validate
103
+ # @param parameter_name [String] the parameter name for error messages
104
+ # @raise [ArgumentError] if string is nil or empty
105
+ def validate_required_string(value, parameter_name)
106
+ raise ArgumentError, "#{parameter_name} cannot be nil" if value.nil?
107
+ raise ArgumentError, "#{parameter_name} cannot be empty" if value.to_s.strip.empty?
108
+ end
109
+ end
110
+ end
111
+ end
112
+ end
@@ -1,101 +1,101 @@
1
- # frozen_string_literal: true
2
-
3
- require_relative "../configuration/project"
4
-
5
- module Makit
6
- module Setup
7
- class ClassLib
8
- def self.run
9
- # puts "Setting up Nuget project..."
10
- project = Makit::Configuration::Project.default
11
-
12
- dotnet_project_directory = "source/#{project.name}"
13
- dotnet_project = Makit::Configuration::DotNetProject.new
14
- dotnet_project.name = project.name
15
- dotnet_project.template = "classlib"
16
- dotnet_project.output_dir = dotnet_project_directory
17
- dotnet_project.frameworks = ["net8.0", "net8.0-browser"]
18
-
19
- project_filename = "source/#{project.name}/#{project.name}.csproj"
20
- if (!File.exist?(project_filename))
21
- Makit::DotNet::Project.new_project("classlib", project.name, "source/#{project.name}", "--framework net8.0")
22
- dotnet_project = Makit::DotNet::Project.new("source/#{project.name}/#{project.name}.csproj")
23
- # set the version to project.version
24
- dotnet_project.set_version(project.version)
25
- # set the frameworks = ["net8.0","net8.0-browser"]
26
- dotnet_project.set_target_frameworks(["net8.0", "net8.0-browser"])
27
- # set the nuget metadata
28
- dotnet_project.set_nuget_metadata(project.name, project.authors, project.description,
29
- project.license_expression)
30
- end
31
-
32
- test_project_filename = "tests/#{project.name}.Tests/#{project.name}.Tests.csproj"
33
- if (File.exist?(test_project_filename))
34
- Makit::DotNet::Project.new_project("TUnit", "#{project.name}.Tests", "tests/#{project.name}.Tests")
35
- dotnet_project = Makit::DotNet::Project.new("tests/#{project.name}.Tests/#{project.name}.Tests.csproj")
36
- # set the version to project.version
37
- dotnet_project.set_version(project.version)
38
- # set the frameworks = ["net8.0","net8.0-browser"]
39
- dotnet_project.set_target_frameworks(["net8.0"])
40
- # set the nuget metadata
41
- dotnet_project.set_nuget_metadata("#{project.name}.Tests", project.authors, project.description,
42
- project.license_expression)
43
- Makit::DotNet::Project.add_reference("tests/#{project.name}/#{project.name}.Tests.csproj",
44
- "source/#{project.name}/#{project.name}.csproj")
45
- end
46
- update_build_step(project)
47
- update_test_step(project)
48
-
49
- project.save
50
-
51
- # Setup the sln, then slnx
52
- if (!File.exist?("#{project.name}.slnx"))
53
- Makit::DotNet.new_solution(project.name)
54
- Makit::DotNet.sln_add_projects(project.name)
55
- # migrate the sln to slnx
56
- "dotnet sln migrate #{project.name}.sln".run
57
- FileUtils.rm_f("#{project.name}.sln") if File.exist?("#{project.name}.slnx")
58
- end
59
- Makit::Logging.default_logger.debug("Project setup completed")
60
- end
61
-
62
- def self.update_build_step(project)
63
- build_commands = []
64
- build_commands << "dotnet restore #{project.name}.slnx" if File.exist?("#{project.name}.slnx")
65
- build_commands << "dotnet build source/#{project.name}/#{project.name}.csproj --configuration Release"
66
- build_commands << "dotnet build tests/#{project.name}.Tests/#{project.name}.Tests.csproj --configuration Release"
67
- build_commands << "dotnet pack source/#{project.name}/#{project.name}.csproj --configuration Release --output artifacts/Packages"
68
- build_commands << "dotnet pack tests/#{project.name}.Tests/#{project.name}.Tests.csproj --configuration Release --output artifacts/Packages"
69
- steps = project.steps
70
- if steps.any? { |step| step.name == "build" }
71
- build_step = steps.find { |step| step.name == "build" }
72
- build_step.commands = build_commands
73
- else
74
- build_step = Makit::Configuration::Step.new(name: "build", description: "Build the project artifacts",
75
- commands: build_commands)
76
- build_step.commands = build_commands
77
- project.add_step(build_step)
78
- end
79
- build_step.commands = build_commands
80
-
81
- project.save
82
- end
83
-
84
- def self.update_test_step(project)
85
- test_commands = []
86
- test_commands << "dotnet test tests/#{project.name}/#{project.name}.Tests.csproj"
87
- steps = project.steps
88
- if steps.any? { |step| step.name == "test" }
89
- test_step = steps.find { |step| step.name == "test" }
90
- test_step.commands = test_commands
91
- else
92
- test_step = Makit::Configuration::Step.new(name: "test", description: "Run the project tests",
93
- commands: test_commands)
94
- test_step.commands = test_commands
95
- project.add_step(test_step)
96
- end
97
- project.save
98
- end
99
- end
100
- end
101
- end
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../configuration/project"
4
+
5
+ module Makit
6
+ module Setup
7
+ class ClassLib
8
+ def self.run
9
+ # puts "Setting up Nuget project..."
10
+ project = Makit::Configuration::Project.default
11
+
12
+ dotnet_project_directory = "source/#{project.name}"
13
+ dotnet_project = Makit::Configuration::DotNetProject.new
14
+ dotnet_project.name = project.name
15
+ dotnet_project.template = "classlib"
16
+ dotnet_project.output_dir = dotnet_project_directory
17
+ dotnet_project.frameworks = ["net8.0", "net8.0-browser"]
18
+
19
+ project_filename = "source/#{project.name}/#{project.name}.csproj"
20
+ if (!File.exist?(project_filename))
21
+ Makit::DotNet::Project.new_project("classlib", project.name, "source/#{project.name}", "--framework net8.0")
22
+ dotnet_project = Makit::DotNet::Project.new("source/#{project.name}/#{project.name}.csproj")
23
+ # set the version to project.version
24
+ dotnet_project.set_version(project.version)
25
+ # set the frameworks = ["net8.0","net8.0-browser"]
26
+ dotnet_project.set_target_frameworks(["net8.0", "net8.0-browser"])
27
+ # set the nuget metadata
28
+ dotnet_project.set_nuget_metadata(project.name, project.authors, project.description,
29
+ project.license_expression)
30
+ end
31
+
32
+ test_project_filename = "tests/#{project.name}.Tests/#{project.name}.Tests.csproj"
33
+ if (File.exist?(test_project_filename))
34
+ Makit::DotNet::Project.new_project("TUnit", "#{project.name}.Tests", "tests/#{project.name}.Tests")
35
+ dotnet_project = Makit::DotNet::Project.new("tests/#{project.name}.Tests/#{project.name}.Tests.csproj")
36
+ # set the version to project.version
37
+ dotnet_project.set_version(project.version)
38
+ # set the frameworks = ["net8.0","net8.0-browser"]
39
+ dotnet_project.set_target_frameworks(["net8.0"])
40
+ # set the nuget metadata
41
+ dotnet_project.set_nuget_metadata("#{project.name}.Tests", project.authors, project.description,
42
+ project.license_expression)
43
+ Makit::DotNet::Project.add_reference("tests/#{project.name}/#{project.name}.Tests.csproj",
44
+ "source/#{project.name}/#{project.name}.csproj")
45
+ end
46
+ update_build_step(project)
47
+ update_test_step(project)
48
+
49
+ project.save
50
+
51
+ # Setup the sln, then slnx
52
+ if (!File.exist?("#{project.name}.slnx"))
53
+ Makit::DotNet.new_solution(project.name)
54
+ Makit::DotNet.sln_add_projects(project.name)
55
+ # migrate the sln to slnx
56
+ "dotnet sln migrate #{project.name}.sln".run
57
+ FileUtils.rm_f("#{project.name}.sln") if File.exist?("#{project.name}.slnx")
58
+ end
59
+ Makit::Logging.default_logger.debug("Project setup completed")
60
+ end
61
+
62
+ def self.update_build_step(project)
63
+ build_commands = []
64
+ build_commands << "dotnet restore #{project.name}.slnx" if File.exist?("#{project.name}.slnx")
65
+ build_commands << "dotnet build source/#{project.name}/#{project.name}.csproj --configuration Release"
66
+ build_commands << "dotnet build tests/#{project.name}.Tests/#{project.name}.Tests.csproj --configuration Release"
67
+ build_commands << "dotnet pack source/#{project.name}/#{project.name}.csproj --configuration Release --output artifacts/Packages"
68
+ build_commands << "dotnet pack tests/#{project.name}.Tests/#{project.name}.Tests.csproj --configuration Release --output artifacts/Packages"
69
+ steps = project.steps
70
+ if steps.any? { |step| step.name == "build" }
71
+ build_step = steps.find { |step| step.name == "build" }
72
+ build_step.commands = build_commands
73
+ else
74
+ build_step = Makit::Configuration::Step.new(name: "build", description: "Build the project artifacts",
75
+ commands: build_commands)
76
+ build_step.commands = build_commands
77
+ project.add_step(build_step)
78
+ end
79
+ build_step.commands = build_commands
80
+
81
+ project.save
82
+ end
83
+
84
+ def self.update_test_step(project)
85
+ test_commands = []
86
+ test_commands << "dotnet test tests/#{project.name}/#{project.name}.Tests.csproj"
87
+ steps = project.steps
88
+ if steps.any? { |step| step.name == "test" }
89
+ test_step = steps.find { |step| step.name == "test" }
90
+ test_step.commands = test_commands
91
+ else
92
+ test_step = Makit::Configuration::Step.new(name: "test", description: "Run the project tests",
93
+ commands: test_commands)
94
+ test_step.commands = test_commands
95
+ project.add_step(test_step)
96
+ end
97
+ project.save
98
+ end
99
+ end
100
+ end
101
+ end