Момчил обнови решението на 18.11.2016 23:12 (преди над 8 години)
+RSpec.describe 'Version' do
+ describe '#Version' do
+ it 'can raise ArgumentError if invalid argument is given' do
+ expect { Version.new('1.1.5') }.to_not raise_error
+
+ expect { Version.new('1.1.5.a') }.to raise_error(
+ ArgumentError, "Invalid version string '1.1.5.a'"
+ )
+
+ expect { Version.new('.1.5') }.to raise_error(
+ ArgumentError, "Invalid version string '.1.5'"
+ )
+
+ expect { Version.new('1..5') }.to raise_error(
+ ArgumentError, "Invalid version string '1..5'"
+ )
+
+ expect { Version.new('1.1.5.') }.to raise_error(
+ ArgumentError, "Invalid version string '1.1.5.'"
+ )
+ end
+ end
+
+ describe '#<=>' do
+ it 'can do <=>' do
+ vers1 = Version.new('1.1.5')
+ vers2 = Version.new('1.1.6')
+ vers3 = Version.new('1.1.6')
+
+ expect(vers1 <=> vers2).to eq(-1)
+ expect(vers2 <=> vers3).to eq(0)
+ expect(vers2 <=> vers1).to eq(1)
+ end
+
+ it 'can do <' do
+ vers1 = Version.new('1.1.5')
+ vers2 = Version.new('1.1.6')
+ vers3 = Version.new('1.1.6')
+
+ expect(vers1 < vers2).to eq(true)
+ expect(vers2 < vers3).to eq(false)
+ expect(vers2 < vers1).to eq(false)
+ end
+
+ it 'can do >' do
+ vers1 = Version.new('1.1.5')
+ vers2 = Version.new('1.1.6')
+ vers3 = Version.new('1.1.6')
+
+ expect(vers1 > vers2).to eq(false)
+ expect(vers2 > vers3).to eq(false)
+ expect(vers2 > vers1).to eq(true)
+ end
+
+ it 'can do <=' do
+ vers1 = Version.new('1.1.5')
+ vers2 = Version.new('1.1.6')
+ vers3 = Version.new('1.1.6')
+
+ expect(vers1 <= vers2).to eq(true)
+ expect(vers2 <= vers3).to eq(true)
+ expect(vers2 <= vers1).to eq(false)
+ end
+
+ it 'can do >=' do
+ vers1 = Version.new('1.1.5')
+ vers2 = Version.new('1.1.6')
+ vers3 = Version.new('1.1.6')
+
+ expect(vers1 >= vers2).to eq(false)
+ expect(vers2 >= vers3).to eq(true)
+ expect(vers2 >= vers1).to eq(true)
+ end
+
+ it 'can do ==' do
+ vers1 = Version.new('1.1.5.0')
+ vers2 = Version.new('1.1.5')
+ vers3 = Version.new('1.5.5')
+ vers4 = Version.new('1.1.5')
+
+ expect(vers1 == vers2).to eq(true)
+ expect(vers2 == vers4).to eq(true)
+ expect(vers1 == vers3).to eq(false)
+ end
+ end
+
+ describe '#to_s' do
+ it 'can show the version as a string' do
+ expect(Version.new('1.2.3').to_s).to eq('1.2.3')
+ end
+
+ it 'can show the version as a string without zeroes at the end' do
+ expect(Version.new('1.2.3.0.0.0').to_s).to eq('1.2.3')
+ end
+
+ it 'can show the version as a string without parameter' do
+ expect(Version.new.to_s).to eq('')
+ end
+
+ it 'can show the version as a string with empty string parameter' do
+ expect(Version.new('').to_s).to eq('')
+ expect(Version.new('0').to_s).to eq('')
+ end
+ end
+
+ describe '#components' do
+ it 'can return array of the components' do
+ expect(Version.new('1.2.3').components).to eq([1, 2, 3])
+ end
+
+ it 'can return array of the components without meaningless zeroes' do
+ expect(Version.new('1.2.3.0.0').components).to eq([1, 2, 3])
+ end
+
+ it 'can return array with exact number of components' do
+ expect(Version.new('1.2.3.0.0').components(2)).to eq([1, 2])
+ end
+
+ it 'can return array filled with zeroes if needed' do
+ expect(Version.new('1.2.3').components(5)).to eq([1, 2, 3, 0, 0])
+ end
+
+ it 'does not modify version' do
+ ver = Version.new('1.2.3')
+ string_version = ver.to_s
+
+ expect(ver.components(5)).to eq([1, 2, 3, 0, 0])
+ expect(ver.to_s).to eq(string_version)
+ end
+ end
+
+ describe '#Range' do
+ describe '#include?' do
+ it 'can check with Version objects' do
+ range = Version::Range.new(Version.new('1'), Version.new('2'))
+ vers = Version.new('1.5')
+ vers1 = Version.new('4.5')
+
+ expect(range.include?(vers)).to eq(true)
+ expect(range.include?(vers1)).to eq(false)
+ end
+
+ it 'can check with Version objects and strings' do
+ range = Version::Range.new(Version.new('1'), Version.new('2'))
+ range1 = Version::Range.new('1', Version.new('2'))
+ range2 = Version::Range.new(Version.new('1'), '2')
+ vers = Version.new('1.5')
+ vers1 = Version.new('2.5')
+
+ expect(range.include?('1.5')).to eq(true)
+ expect(range1.include?('1.5')).to eq(true)
+ expect(range2.include?('1.5')).to eq(true)
+ expect(range.include?('2.5')).to eq(false)
+ expect(range1.include?('2.5')).to eq(false)
+ expect(range2.include?('2.5')).to eq(false)
+ expect(range1.include?(vers)).to eq(true)
+ expect(range2.include?(vers)).to eq(true)
+ expect(range1.include?(vers1)).to eq(false)
+ expect(range2.include?(vers1)).to eq(false)
+ end
+
+ it 'can check with strings' do
+ range = Version::Range.new('1', '2')
+
+ expect(range.include?('1.5')).to eq(true)
+ expect(range.include?('3.5')).to eq(false)
+ end
+ end
+
+ describe '#to_a' do
+ it 'returns all versions in the range' do
+ arr = Version::Range.new(
+ Version.new('1.1.0'), Version.new('1.1.3')
+ ).to_a
+ arr1 = Version::Range.new(
+ Version.new('1.0.9'), Version.new('1.2.2')
+ ).to_a
+
+ expect(arr).to eq(['1.1.0', '1.1.1', '1.1.2'])
+ expect(arr1).to eq(
+ [
+ '1.0.9', '1.1.0', '1.1.1', '1.1.2', '1.1.3', '1.1.4', '1.1.5',
+ '1.1.6', '1.1.7', '1.1.8', '1.1.9', '1.2.0', '1.2.1'
+ ]
+ )
+ end
+ end
+ end
+end
Предал съм грешно решение, извинявам се. Дори не си правете труда, да го гледате, моя вина.