File: cli_spec.rb

package info (click to toggle)
ruby-rotp 6.2.0-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 388 kB
  • sloc: ruby: 960; javascript: 325; makefile: 16
file content (68 lines) | stat: -rw-r--r-- 1,709 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
require 'spec_helper'
require 'rotp/cli'

RSpec.describe ROTP::CLI do
  let(:cli)    { described_class.new('executable', argv) }
  let(:output) { cli.output }
  let(:now)    { Time.utc 2012, 1, 1 }

  before do
    Timecop.freeze now
  end

  context 'generating a TOTP' do
    let(:argv) { %w[--secret JBSWY3DPEHPK3PXP] }

    it 'prints the corresponding token' do
      expect(output).to eq '068212'
    end
  end

  context 'generating a TOTP with sha256 digest' do
    let(:argv) { %w[--secret JBSWY3DPEHPK3PXP --digest sha256] }

    it 'prints the corresponding token' do
      expect(output).to eq '544902'
    end
  end

  context 'generating a TOTP with no secret' do
    let(:argv) { %w[--time --secret] }

    it 'prints the corresponding token' do
      expect(output).to match 'You must also specify a --secret'
    end
  end

  context 'generating a TOTP with bad base32 secret' do
    let(:argv) { %W[--time --secret #{'1' * 32}] }

    it 'prints the corresponding token' do
      expect(output).to match 'Secret must be in RFC4648 Base32 format'
    end
  end

  context 'trying to generate an unsupport type' do
    let(:argv) { %W[--notreal --secret #{'a' * 32}] }

    it 'prints the corresponding token' do
      expect(output).to match 'invalid option: --notreal'
    end
  end

  context 'generating a HOTP' do
    let(:argv) { %W[--hmac --secret #{'a' * 32} --counter 1234] }

    it 'prints the corresponding token' do
      expect(output).to eq '161024'
    end
  end

  context 'generating a HOTP' do
    let(:argv) { %W[--hmac --secret #{'a' * 32} --counter 1234 --digest sha256] }

    it 'prints the corresponding token' do
      expect(output).to eq '325941'
    end
  end
end