Skip to content
/ orc Public

indicate computation result success along with status and context

License

Notifications You must be signed in to change notification settings

snusnu/orc

Repository files navigation

orc

Gem Version Build Status Dependency Status Code Climate Coverage Status

Usage

Whenever you want to communicate success or failure of an operation, the following might be handy

describe Orc::Result do
  describe '.success' do
    subject { Orc::Result.success(object) }

    let(:object) { :object }

    it 'signals success' do
      expect(subject.success?).to be(true)
    end

    it 'returns :success status' do
      expect(subject.status).to be(:success)
    end

    it 'exposes the associated object' do
      expect(subject.object).to be(object)
    end
  end

  describe '.failure' do
    shared_context 'a failure result' do
      let(:status) { :confused }
      let(:object) { :context }

      it 'signals failure' do
        expect(subject.success?).to be(false)
      end

      it 'exposes the associated #object' do
        expect(subject.object).to be(object)
      end
    end

    context 'when no status is given' do
      subject { Orc::Result.failure(object) }

      include_context 'a failure result'

      it 'exposes a :failure status' do
        expect(subject.status).to be(:failure)
      end
    end

    context 'when status is given' do
      subject { Orc::Result.failure(object, status) }

      include_context 'a failure result'

      it 'exposes the given #status' do
        expect(subject.status).to be(status)
      end
    end
  end
end

Credits

Contributing

See CONTRIBUTING.md for details.

Copyright

Copyright © 2014 Martin Gamsjaeger (snusnu). See LICENSE for details.

About

indicate computation result success along with status and context

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages