 a8947b5bf3
			
		
	
	a8947b5bf3
	
	
	
		
			
			- Switch to Stein release - Cookstyle fixes - Update cookbook etcd to ~> 5.6 - Update README - Add myself to author list and OSU Copyright - Properly fix completions recipe and ensure it works - Create and start the etcd service in the etcd recipe - Update delivery configuration to exclude integration cookbooks - Refactor and update RenderConfigFileMatcher to work with newer ChefSpec. This fixes output which was passing but showing error messages. Depends-On: https://review.opendev.org/701027 Change-Id: Iba3eeabe85ab9303147e43eeb550212a46d190f3
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # encoding: UTF-8
 | |
| 
 | |
| #
 | |
| # Cookbook:: openstack-common
 | |
| # library:: parse
 | |
| #
 | |
| # Copyright:: 2013, Craig Tracey <craigtracey@gmail.com>
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License");
 | |
| # you may not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| #     http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS,
 | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| 
 | |
| # Parse methods
 | |
| module ::Openstack
 | |
|   # The current state of (at least some) OpenStack CLI tools do not provide a
 | |
|   # mechanism for outputting data in formats other than PrettyTable output.
 | |
|   # Therefore this function is intended to parse PrettyTable output into a
 | |
|   # usable array of hashes. Similarly, it will flatten Property/Value tables
 | |
|   # into a single element array.
 | |
|   # table - the raw PrettyTable output of the CLI command
 | |
|   # output - array of hashes representing the data.
 | |
|   def prettytable_to_array(table)
 | |
|     ret = []
 | |
|     return ret if table.nil?
 | |
|     indicies = []
 | |
|     table.split(/$/).map(&:strip).each do |line|
 | |
|       next if line.start_with?('+--') || line.empty?
 | |
|       cols = line.split('|').map(&:strip)
 | |
|       cols.shift
 | |
|       if indicies == []
 | |
|         indicies = cols
 | |
|         next
 | |
|       end
 | |
|       newobj = {}
 | |
|       cols.each { |val| newobj[indicies[newobj.length]] = val }
 | |
|       ret.push(newobj)
 | |
|     end
 | |
| 
 | |
|     # this kinda sucks, but some prettytable data comes
 | |
|     # as Property Value pairs. If this is the case, then
 | |
|     # flatten it as expected.
 | |
|     newobj = {}
 | |
|     if indicies == %w(Property Value)
 | |
|       ret.each { |x| newobj[x['Property']] = x['Value'] }
 | |
|       [newobj]
 | |
|     else
 | |
|       ret
 | |
|     end
 | |
|   end
 | |
| end
 |