makit 0.0.139 → 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.
- checksums.yaml +4 -4
- data/README.md +41 -41
- data/exe/makit +5 -5
- data/lib/makit/apache.rb +28 -28
- data/lib/makit/auto.rb +48 -48
- data/lib/makit/cli/build_commands.rb +500 -500
- data/lib/makit/cli/generators/base_generator.rb +74 -74
- data/lib/makit/cli/generators/dotnet_generator.rb +50 -50
- data/lib/makit/cli/generators/generator_factory.rb +49 -49
- data/lib/makit/cli/generators/node_generator.rb +50 -50
- data/lib/makit/cli/generators/ruby_generator.rb +77 -77
- data/lib/makit/cli/generators/rust_generator.rb +50 -50
- data/lib/makit/cli/generators/templates/dotnet_templates.rb +167 -167
- data/lib/makit/cli/generators/templates/node_templates.rb +161 -161
- data/lib/makit/cli/generators/templates/ruby/gemfile.rb +26 -26
- data/lib/makit/cli/generators/templates/ruby/gemspec.rb +40 -40
- data/lib/makit/cli/generators/templates/ruby/main_lib.rb +33 -33
- data/lib/makit/cli/generators/templates/ruby/rakefile.rb +35 -35
- data/lib/makit/cli/generators/templates/ruby/readme.rb +63 -63
- data/lib/makit/cli/generators/templates/ruby/test.rb +39 -39
- data/lib/makit/cli/generators/templates/ruby/test_helper.rb +29 -29
- data/lib/makit/cli/generators/templates/ruby/version.rb +29 -29
- data/lib/makit/cli/generators/templates/rust_templates.rb +128 -128
- data/lib/makit/cli/main.rb +69 -67
- data/lib/makit/cli/project_commands.rb +868 -868
- data/lib/makit/cli/repository_commands.rb +661 -661
- data/lib/makit/cli/strategy_commands.rb +51 -0
- data/lib/makit/cli/utility_commands.rb +521 -521
- data/lib/makit/commands/factory.rb +359 -359
- data/lib/makit/commands/middleware/base.rb +73 -73
- data/lib/makit/commands/middleware/cache.rb +248 -248
- data/lib/makit/commands/middleware/command_logger.rb +312 -312
- data/lib/makit/commands/middleware/validator.rb +269 -269
- data/lib/makit/commands/request.rb +316 -316
- data/lib/makit/commands/result.rb +323 -323
- data/lib/makit/commands/runner.rb +385 -385
- data/lib/makit/commands/strategies/base.rb +171 -171
- data/lib/makit/commands/strategies/child_process.rb +1 -1
- data/lib/makit/commands/strategies/synchronous.rb +139 -139
- data/lib/makit/commands.rb +50 -50
- data/lib/makit/configuration/dotnet_project.rb +12 -12
- data/lib/makit/configuration/gitlab_helper.rb +58 -58
- data/lib/makit/configuration/project.rb +168 -168
- data/lib/makit/configuration/rakefile_helper.rb +43 -43
- data/lib/makit/configuration/step.rb +34 -34
- data/lib/makit/configuration/timeout.rb +74 -0
- data/lib/makit/configuration.rb +15 -14
- data/lib/makit/content/default_gitignore.rb +7 -7
- data/lib/makit/content/default_gitignore.txt +225 -225
- data/lib/makit/content/default_rakefile.rb +13 -13
- data/lib/makit/content/gem_rakefile.rb +16 -16
- data/lib/makit/context.rb +1 -1
- data/lib/makit/data.rb +49 -49
- data/lib/makit/directories.rb +140 -140
- data/lib/makit/directory.rb +262 -262
- data/lib/makit/docs/files.rb +89 -89
- data/lib/makit/docs/rake.rb +102 -102
- data/lib/makit/dotnet/cli.rb +69 -69
- data/lib/makit/dotnet/project.rb +217 -217
- data/lib/makit/dotnet/solution.rb +38 -38
- data/lib/makit/dotnet/solution_classlib.rb +239 -239
- data/lib/makit/dotnet/solution_console.rb +264 -264
- data/lib/makit/dotnet/solution_maui.rb +354 -354
- data/lib/makit/dotnet/solution_wasm.rb +275 -275
- data/lib/makit/dotnet/solution_wpf.rb +304 -304
- data/lib/makit/dotnet.rb +102 -102
- data/lib/makit/email.rb +90 -90
- data/lib/makit/environment.rb +142 -142
- data/lib/makit/examples/runner.rb +370 -370
- data/lib/makit/exceptions.rb +45 -45
- data/lib/makit/fileinfo.rb +24 -24
- data/lib/makit/files.rb +43 -43
- data/lib/makit/gems.rb +40 -40
- data/lib/makit/git/cli.rb +54 -54
- data/lib/makit/git/repository.rb +90 -90
- data/lib/makit/git.rb +98 -98
- data/lib/makit/gitlab_runner.rb +59 -59
- data/lib/makit/humanize.rb +137 -137
- data/lib/makit/indexer.rb +47 -47
- data/lib/makit/logging/configuration.rb +308 -308
- data/lib/makit/logging/format_registry.rb +84 -84
- data/lib/makit/logging/formatters/base.rb +39 -39
- data/lib/makit/logging/formatters/console_formatter.rb +140 -140
- data/lib/makit/logging/formatters/json_formatter.rb +65 -65
- data/lib/makit/logging/formatters/plain_text_formatter.rb +71 -71
- data/lib/makit/logging/formatters/text_formatter.rb +64 -64
- data/lib/makit/logging/log_request.rb +119 -119
- data/lib/makit/logging/logger.rb +199 -199
- data/lib/makit/logging/sinks/base.rb +91 -91
- data/lib/makit/logging/sinks/console.rb +72 -72
- data/lib/makit/logging/sinks/file_sink.rb +92 -92
- data/lib/makit/logging/sinks/structured.rb +123 -123
- data/lib/makit/logging/sinks/unified_file_sink.rb +296 -296
- data/lib/makit/logging.rb +565 -565
- data/lib/makit/markdown.rb +75 -75
- data/lib/makit/mp/basic_object_mp.rb +17 -17
- data/lib/makit/mp/command_mp.rb +13 -13
- data/lib/makit/mp/command_request.mp.rb +17 -17
- data/lib/makit/mp/project_mp.rb +199 -199
- data/lib/makit/mp/string_mp.rb +191 -191
- data/lib/makit/nuget.rb +74 -74
- data/lib/makit/port.rb +32 -32
- data/lib/makit/process.rb +163 -163
- data/lib/makit/protoc.rb +107 -107
- data/lib/makit/rake/cli.rb +196 -196
- data/lib/makit/rake.rb +80 -80
- data/lib/makit/ruby/cli.rb +185 -185
- data/lib/makit/ruby.rb +25 -25
- data/lib/makit/secrets.rb +51 -51
- data/lib/makit/serializer.rb +130 -130
- data/lib/makit/services/builder.rb +186 -186
- data/lib/makit/services/error_handler.rb +226 -226
- data/lib/makit/services/repository_manager.rb +231 -231
- data/lib/makit/services/validator.rb +112 -112
- data/lib/makit/setup/classlib.rb +101 -101
- data/lib/makit/setup/gem.rb +268 -268
- data/lib/makit/setup/razorclasslib.rb +101 -101
- data/lib/makit/setup/runner.rb +54 -54
- data/lib/makit/setup.rb +5 -5
- data/lib/makit/show.rb +110 -110
- data/lib/makit/storage.rb +126 -126
- data/lib/makit/symbols.rb +170 -170
- data/lib/makit/task_info.rb +130 -130
- data/lib/makit/tasks/at_exit.rb +15 -15
- data/lib/makit/tasks/build.rb +22 -22
- data/lib/makit/tasks/clean.rb +13 -13
- data/lib/makit/tasks/configure.rb +10 -10
- data/lib/makit/tasks/format.rb +10 -10
- data/lib/makit/tasks/hook_manager.rb +443 -443
- data/lib/makit/tasks/init.rb +49 -49
- data/lib/makit/tasks/integrate.rb +29 -29
- data/lib/makit/tasks/pull_incoming.rb +13 -13
- data/lib/makit/tasks/setup.rb +13 -13
- data/lib/makit/tasks/sync.rb +17 -17
- data/lib/makit/tasks/tag.rb +16 -16
- data/lib/makit/tasks/task_monkey_patch.rb +81 -81
- data/lib/makit/tasks/test.rb +22 -22
- data/lib/makit/tasks/update.rb +18 -18
- data/lib/makit/tasks.rb +20 -20
- data/lib/makit/test_cache.rb +239 -239
- data/lib/makit/tree.rb +37 -37
- data/lib/makit/v1/makit.v1_pb.rb +35 -35
- data/lib/makit/v1/makit.v1_services_pb.rb +27 -27
- data/lib/makit/version.rb +99 -99
- data/lib/makit/version_util.rb +21 -21
- data/lib/makit/wix.rb +95 -95
- data/lib/makit/yaml.rb +29 -29
- data/lib/makit/zip.rb +17 -17
- data/lib/makit copy.rb +44 -44
- data/lib/makit.rb +42 -42
- metadata +2 -1
@@ -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
|
data/lib/makit/setup/classlib.rb
CHANGED
@@ -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
|