-
Notifications
You must be signed in to change notification settings - Fork 245
Multiple Upgrades to the Azure Ruby SDK #1064
Conversation
1. Combined all the profiles json files to one file 2. Bug fix to include azure_sdk in build and release process 3. Removed all the relative paths. 4. Split the rollup and individual templates to get a cleaner code 5. Cleaned up Rakefile
@sarangan12 I believe you're addressing parts of #1034. Could you split out an issue that contains only the things you planned to address with this PR? I'd like to make sure we're able to track what's pending and have issues with titles that represent what's getting addressed. |
Added a new commit to include code changes related to Independent Versioning of gems. Provided a short description on the changes included:
How will these changes impact the Jenkins Publish Job? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Made a bunch of comments inline.
Trying to look at the pieces carefully, still have more to go for the generators, will continue and post more.
|
||
desc 'Azure Resource Manager related tasks which often traverse each of the arm gems' | ||
namespace :arm do | ||
desc 'Delete ./pkg for each of the Azure Resource Manager projects' | ||
task :clean do | ||
each_gem do | ||
execute_and_stream(OS.windows? ? 'del /S /Q pkg 2>nul' : 'rm -rf ./pkg') | ||
FileUtils.rm_rf('pkg') | ||
end | ||
end | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
in clean_generated task below, we should enable the ability to clean by gem or based on what's in the list for generation.
Before, when generating a specific gem, we would only delete that one, now, we're deleting everything, even though the generation based on the file, may only be generating a few.
@@ -0,0 +1,64 @@ | |||
{ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could we track all gem versions in the "config.json" file with package_version and eliminate this file?
If necessary config.json, could have a "more general" version, so we don't need to specify it for each api-version, which is actually kind of redundant (was done that way to simplify format of the file at least initially)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The missing piece if we remove this file would be azure_sdk, but I believe we could 1) have a version file in the azure_sdk folder for this "special" gem, 2) add it to config.json changing the format of the file a bit.
version = File.read(File.expand_path('../ARM_VERSION', __FILE__)).strip | ||
gem_versions = JSON.parse(File.read(File.expand_path('../GEM_VERSIONS', __FILE__)).strip) | ||
gems_to_release = JSON.parse(File.read(File.expand_path('../GEMS_TO_RELEASE', __FILE__)).strip) | ||
GEMS_TO_IGNORE = ['azure_mgmt_insights'] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should we just remove insights from all lists and repo? What's the intended difference between GEMS_TO_IGNORE and a combination of REGEN_EXCLUDES and GEMS_TO_RELEASE?
|
||
desc 'Azure Resource Manager related tasks which often traverse each of the arm gems' | ||
namespace :arm do | ||
desc 'Delete ./pkg for each of the Azure Resource Manager projects' | ||
task :clean do | ||
each_gem do | ||
execute_and_stream(OS.windows? ? 'del /S /Q pkg 2>nul' : 'rm -rf ./pkg') | ||
FileUtils.rm_rf('pkg') |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
(Y)
gems_to_release.each do |key, gems| | ||
gems.each do |gem| | ||
if(key == 'rollup') | ||
Dir.chdir("#{__dir__}/azure_sdk") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should we be picking the name from #{gem} and not hardcode "azure_sdk"?
@@ -5,8 +5,10 @@ | |||
lib = File.expand_path('../lib', __FILE__) | |||
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib) | |||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should we have this file be generated? If we add/remove gems, we would need to manually update this one. I know we missed adding some gems to the list before, so wondering.
@credentials = MsRest::TokenCredentials.new( | ||
MsRestAzure::ApplicationTokenProvider.new( | ||
@tenant_id, @client_id, @client_secret, @active_directory_settings)) | ||
@options = { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
per our conversation this morning with env and credentials, this may need to be updated.
config.json
Outdated
@@ -3,87 +3,75 @@ | |||
"azure_mgmt_analysis_services_2017_07_14": { | |||
"markdown": "https://raw.githubusercontent.com/Azure/azure-rest-api-specs/7aa3a5247895ba34d6cfec73e036bb66dc907d20/specification/analysisservices/resource-manager/readme.md", | |||
"namespace": "Azure::AnalysisServices::Mgmt::V2017_07_14", | |||
"package-version": "0.15.0", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
per some of my previous comments, could we have this version in this file and avoid having to add a new file for gem versions?
@@ -69,12 +68,9 @@ def generate_modules | |||
@spec_includes << @module_require |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could there be more than module_required?
could there be several RPs pointing to the same module_required?
@@ -69,12 +68,9 @@ def generate_modules | |||
@spec_includes << @module_require | |||
@class_name = get_ruby_specific_resource_type_name(resource_provider) | |||
@class_names << @class_name | |||
if(!@individual_gem_profile) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
if this file will only be used for individual gem profile, should its name be updated to indicate this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
More comments inline.
@@ -29,6 +30,10 @@ def self.parse(args) | |||
options.mode = mode |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
minor suggestion: if mode value is incorrect, we may want to raise InvalidArgument, InvalidOption seems to be applicable when the switch is undefined.
@@ -29,6 +30,10 @@ def self.parse(args) | |||
options.mode = mode | |||
end | |||
|
|||
opts.on('-sSDK_PATH', '--sdk_path=SDK_PATH', 'SDK Path') do |sdk_path| |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could we have a better description to what this means?, the switch name indicates it's an sdk_path, but probably not clear what the format should be (relative starting somewhere? absolute path?), it may be helpful to indicate what's being used for.
@@ -11,10 +11,10 @@ class RequireFileGenerator | |||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can you add a description at the top of this class? The name "require file generator" doesn't seem very indicative of what this is. It contains requires, but it's really the file that gets the rest of the code loaded, is there a better name for this?
We should indicate as well, that the name of the file that gets generated is actually the gem name, and that this file is at top level in terms of the gem, and what the purpose of it is.
@@ -11,10 +11,10 @@ class RequireFileGenerator | |||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should not be hard-coding a gem name to exclude here, why do we need an "EXCLUDE_GEMS" in this generator? What we generate should be consistent with what gets generated by the profile generator.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should this generator be structured to be called per gem (either rollup or individual)? So, when we want to generate new files for a gem we would call "generate profile" for a gem which would do a sub call to generate the "require file" for that specific gem, in which case, it should probably get the location where generation is producing code for that gem as input.
@@ -55,7 +55,7 @@ def initialize(azure_sdk_location, mgmt_sdks_location) | |||
# | |||
def generate_require_files_for_individual_gems | |||
puts 'Generating require files for individual gems' | |||
Dir.chdir("#{@current_location}/#{@mgmt_sdks_location}") | |||
Dir.chdir("#{@mgmt_sdks_location}") | |||
gems = Dir['*'].reject{|o| not File.directory?(o)} | |||
gems.each do |gem| | |||
# azure_mgmt_insights is a special case gem which we have stopped |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
btw, should we remove insights folder from our latest code, since we're not updating it and not shipping it?
@@ -13,6 +13,9 @@ | |||
# -h, --help : Displays help for the profile generator | |||
# -d, --dir_metadata : File that contains metadata info about RPs | |||
# -p, --profile : Input file contains the profile generation info about RPs, versions, etc. | |||
# -m, --mode : Mode can be 'rollup'/ 'management' | |||
# -k, --key : Key of the Profile |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what's key of the profile?
@@ -13,6 +13,9 @@ | |||
# -h, --help : Displays help for the profile generator | |||
# -d, --dir_metadata : File that contains metadata info about RPs | |||
# -p, --profile : Input file contains the profile generation info about RPs, versions, etc. | |||
# -m, --mode : Mode can be 'rollup'/ 'management' | |||
# -k, --key : Key of the Profile | |||
# -s, --sdk_path : Path to Azure Ruby SDK |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can you provide more info on what the format of the path here should be?
@@ -13,6 +13,9 @@ | |||
# -h, --help : Displays help for the profile generator | |||
# -d, --dir_metadata : File that contains metadata info about RPs | |||
# -p, --profile : Input file contains the profile generation info about RPs, versions, etc. | |||
# -m, --mode : Mode can be 'rollup'/ 'management' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
would we not support "dataplane"? what would be different profile generator wise? is there a reason why the options are not rolloup & individual as in other cases?
@@ -69,12 +68,9 @@ def generate_modules | |||
@spec_includes << @module_require | |||
@class_name = get_ruby_specific_resource_type_name(resource_provider) | |||
@class_names << @class_name | |||
if(!@individual_gem_profile) | |||
@default_rp_client_version = @default_versions[resource_provider] | |||
end | |||
|
|||
resource_types_obj.each do |resource_type_version, resource_types| |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could you add some inline comments to help follow the logic?
@@ -126,7 +121,7 @@ def check_available_after_index(operation_type_to_check, index_after_to_compare) | |||
# | |||
def generate_client | |||
file = get_client_file |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
similar to a comment I made in another place, should we have a method to create a file based on a name and template, seems that we do that in multiple places and not very consistent across the generator methods.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I left a couple of comments, please review and address as necessary before merging.
Approving conditionally on that and also on what we discussed, that you'll be creating issues for all the other comments made to address in a subsequent PR.
@@ -21,15 +21,5 @@ module Azure::<%= @class_name %>::Profiles::<%= @profile_name %>::Mgmt | |||
super(options) | |||
end | |||
|
|||
def credentials | |||
if @credentials.nil? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
shouldn't this change have come as part of the merge? with merged PR https://github.com/Azure/azure-sdk-for-ruby/pull/1090/files ?
I'm curious on what else we could have missed in the merge, therefore the question.
Rakefile
Outdated
@@ -242,7 +247,7 @@ Rake::Task['arm:regen_individual_profiles'].enhance do | |||
Rake::Task['arm:regen_individual_require_files'].invoke | |||
end | |||
|
|||
Rake::Task['arm:regen'].enhance do | |||
Rake::Task['arm:regen_sdk_versions'].enhance do |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
change is ok. I think I made a comment on this before, on what's the benefit of enhance? could we be consistent and have the regen_sdk_versions task just call regen_individual_require_files as a pre-req?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually, You cannot make regen_individual_require_files a pre requisite. If you execute regen_individual_require_files before regen_sdk_versions task, the require file will be empty. Because, in order to generate the require files, the sdk versions must be generated. i.e. you need to execute regen_individual_require_files task AFTER the regen_sdk_versions task. Now, it is possible to create a third task and make both of them as pre reqs. But, according to rake specification the order is not guaranteed. So, enhancement is the only option. Also, enhancement is standard design option provided by Rake and I believe we must start using it.
Combined all the profiles json files to one file
There were 50+ files for profile specifications, each specific to a service. This will be difficult to maintain in the future. So, With this PR, all the 50+ files have been combined to one file (and corresponding code changes to handle the merge)
Bug fix to include azure_sdk in build and release process
The build and release process did not include the azure_sdk. As a result, this gem was not included automatically in the previous release and needed manual intervention. So, With this PR, that issue has been fixed and the azure_sdk has been included in the build and release process.
Removed all the relative paths
The Metadata files and profiles files have relative paths in them which would cause issues in the future (such as moving the generator out). With this PR, all the relative paths have been removed.
Split the rollup and individual templates to get a cleaner code
The Template files for the Rollup profiles and Individual profiles were same. So, they had several if conditions all over which would definitely cause issues in the future when we want to make changes. With this PR, they are completely split and independent which would make the future enhancements easier.
Cleaned the Rakefile
The Rakefile had some unnecessary code and also complex Directory changes which will result in warnings during the regeneration. With this PR, such issues have been cleared.
None of these changes resulted in any code changes within the SDK. I have executed the bundle exec rake arm:regen && bundle exec rake arm:regen_all_profiles and this has caused 0 changes.
@veronicagg @vishrutshah @salameer @devigned Please review and approve