Project

fakecmd

0.0
No commit activity in last 3 years
No release in over 3 years
Fakes system commands. Intended for use in tests.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 0
~> 2
>= 0
 Project Readme

fakecmd

Build Status Gem Version

Fakes system commands. Intended for use in tests. If your code relies on system commands and perhaps verifies their exit status, you may not want to rely on the OS to be able to run your tests. Especially so if these commands have side effects or take a long time to run. Originally inspired by FakeFS.

Example

module Users
  def self.count
    c = %x(users).split.size
    c if $?.exitstatus == 0
  end
end

class UsersTest < Test::Unit::TestCase
  def setup
    FakeCmd.clear!
  end

  def test_count_success
    FakeCmd.add :users, 0, "a b c"
    assert_equal 3, FakeCmd { Users.count }
    assert_equal 0, $?.exitstatus
  end

  def test_count_failure
    FakeCmd.add :users, 1
    assert_nil FakeCmd { Users.count }
    assert_equal 1, $?.exitstatus
  end
end
  • FakeCmd.clear! clears the current collection of faked commands, if any.

  • FakeCmd.add :users, 0, "a b c" fakes the users command, defines its exit status to be 0, and its output to be a b c. :users could have been a string or regular expression as well; internally, everything is a regular expression.

  • FakeCmd { Users.count } calls Users.count in the faked environment. You can also use FakeCmd.on! and FakeCmd.off! to turn it on and off, respectively. No system command using the backtick or %x notation will be executed in the block or between .on! and .off!. system "" will be executed if the command is not found in the collection.

  • $?.exitstatus reflects the exit status given to .add.

Keep in mind that only the following calls will be faked:

``
%x

Installation

gem install fakecmd