Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

skip suite and test without failing #332

Closed
ehartford opened this issue Mar 19, 2012 · 72 comments
Closed

skip suite and test without failing #332

ehartford opened this issue Mar 19, 2012 · 72 comments
Labels
type: feature enhancement proposal

Comments

@ehartford
Copy link

I would like some function like skipTest() and skipSuite() that would allow me to skip a test or suite without failing it.

If you are in suiteSetup() then you could skip the suite
if you are in test() then you could skip the rest of the suite or the test
if you are in setup() then you could skip the rest of the suite or the test
if you are in tearDown() then you could skip rest of the suite
if you are in suiteTearDown() then you could not skip either

@Almad
Copy link

Almad commented May 2, 2012

+1

2 similar comments
@darthdeus
Copy link

+1

@ericchaves
Copy link

+1

@tj
Copy link
Contributor

tj commented Jun 17, 2012

This issue has been inactive for over 1 month so I'm closing it. If you think it's still an issue re-open. - tjbot

@tj tj closed this as completed Jun 17, 2012
@Almad
Copy link

Almad commented Jun 17, 2012

AFAIK it is still an issue ,)

@darthdeus
Copy link

This is definitely still an issue.

@ehartford
Copy link
Author

still issue please

@tj
Copy link
Contributor

tj commented Jun 17, 2012

hmm i never even saw this issue. I'm not sure I get it, what would this be useful for? Is this fixed by xdescribe( and xit() ? (we could add similar to the tdd interface)

@ehartford
Copy link
Author

Many reasons to skip without fail.

  1. wrong platform for test
  2. test is disabled
  3. a service test depends on is not responding
  4. a required environment variable or parameter is not set

@tj
Copy link
Contributor

tj commented Jun 17, 2012

well:

  1. should use --grep
  2. should not supply a callback (making it pending), or use xdescribe / xit
  3. should mock these services if they're not readily available
  4. not sure

@ehartford
Copy link
Author

Does not invalidate need to skip without fail.

Sent from my iPhone

On Jun 17, 2012, at 11:50 AM, TJ Holowaychuk
reply@reply.github.com
wrote:

well:

  1. should use --grep
  2. should not supply a callback (making it pending), or use xdescribe / xit
  3. should mock these services if they're not readily available
  4. not sure

Reply to this email directly or view it on GitHub:
#332 (comment)

@tj
Copy link
Contributor

tj commented Jun 17, 2012

I'm open to the idea but I'm not sold on the idea of needing to conditionally skip tests. Even if that's the case --grep is great for that, or just separate those tests into other files and dont load them for some envs

@ehartford
Copy link
Author

Sometimes you cannot know until you are actually in the test.

Sent from my iPhone

On Jun 17, 2012, at 11:54 AM, TJ Holowaychuk
reply@reply.github.com
wrote:

I'm open to the idea but I'm not sold on the idea of needing to conditionally skip tests. Even if that's the case --grep is great for that, or just separate those tests into other files and dont load them for some envs


Reply to this email directly or view it on GitHub:
#332 (comment)

@tj
Copy link
Contributor

tj commented Jun 17, 2012

sure, but I would argue that it's not a very good test if you have to conditionally skip it. If some external service is not available then it should be mocked etc, or use an environment variable to toggle wether or not it's hitting the service or the mock

@ehartford
Copy link
Author

Sometimes not possible

Sent from my iPhone

On Jun 17, 2012, at 12:05 PM, TJ Holowaychuk
reply@reply.github.com
wrote:

sure, but I would argue that it's not a very good test if you have to conditionally skip it. If some external service is not available then it should be mocked etc, or use an environment variable to toggle wether or not it's hitting the service or the mock


Reply to this email directly or view it on GitHub:
#332 (comment)

@ehartford
Copy link
Author

You are thinking only of unit tests;
Mocha is used for larger integration tests and end to end tests too
where the environment is not so deterministic.

Please believe me I have 10 years exp in software test industry and a
masters degree and you are treating me like an undergrad...

Sent from my iPhone

On Jun 17, 2012, at 12:05 PM, TJ Holowaychuk
reply@reply.github.com
wrote:

sure, but I would argue that it's not a very good test if you have to conditionally skip it. If some external service is not available then it should be mocked etc, or use an environment variable to toggle wether or not it's hitting the service or the mock


Reply to this email directly or view it on GitHub:
#332 (comment)

@ehartford
Copy link
Author

anyway apparently I am not expert enough so I will just stop talking and let the other +1's pipe in with their perspectives.

@tj
Copy link
Contributor

tj commented Jun 17, 2012

nah man I dont mean any offense, I just nitpick because I'm trying to understand the use-cases better before committing to an API that I need to maintain that's all

@ehartford
Copy link
Author

I understand :-)

@tj
Copy link
Contributor

tj commented Jun 17, 2012

plus there are several +1's in here so it definitely seems like something people want, I just need use-cases so I can figure out what the best way to approach this is

@Almad
Copy link

Almad commented Jun 18, 2012

@visionmedia My use case is this: I have integration tests that test that when I execute code snippet displayed on web page is doing the right thing.

This is done by executing code in subprocess. However, we have fair number of such snippets and for some of those, environment might not be installed (i.e. F# binary). I would like to mark those as skipped...

@tj
Copy link
Contributor

tj commented Jun 18, 2012

@Almad but why not tag them with "f#" or similar, it('should do something f#', callback) and --grep conditionally. Or why not split these ones into other files and load those conditionally? that's effectively the same thing, just organized better

@Almad
Copy link

Almad commented Jun 18, 2012

@visionmedia I would prefer unified starting interface so that executor don't have to know which tests to select.

@tj
Copy link
Contributor

tj commented Jun 18, 2012

I'll think about it, this just seems like a very weird way to handle it

@pedrosnk
Copy link

We have a simple use case for it. We have a system which can act in two different modes, and many functions are disabled in one of these modes. The mode is toggled by an environment variable, and we'd like to skip all the tests for the affected functions based on the same environment variable.

@tj
Copy link
Contributor

tj commented Oct 18, 2012

@pedrosnk that's mostly an organizational problem, you could for example use https://github.com/visionmedia/mocha/wiki/Tagging

@ehartford
Copy link
Author

I just dont get why you are so opposed to this. Every other test harness
I've worked with has this feature.
On Oct 18, 2012 11:40 AM, "TJ Holowaychuk" notifications@github.com wrote:

@pedrosnk https://github.com/pedrosnk that's mostly an organizational
problem, you could for example use
https://github.com/visionmedia/mocha/wiki/Tagging


Reply to this email directly or view it on GitHubhttps://github.com//issues/332#issuecomment-9576865.

@tj
Copy link
Contributor

tj commented Oct 18, 2012

because every feature I add includes additional baggage that I have to maintain, no feature should be added without discussion unless it's clearly needed. This is definitely one I've never needed, and it can easily be bypassed using other existing features IMO

@geek
Copy link

geek commented Oct 24, 2012

I have also bumped into this limitation. Here is another use case: a set of integration tests you want to skip when a service isn't running. Wrapping the describe in an if works, but it doesn't notify the dev running the tests that some things were skipped. Failing isn't an option because certain integration environments can't have these dependent services running. The ability to skip from within a before() is the best solution to this problem.

@boneskull
Copy link
Contributor

@jbnicolai Hmm, @visionmedia gave me push access, so I don't know what that means exactly for "maintainer" status. Anyway, I have push access, so Hi. I hope to help w/ cleaning up this backlog of issues.

@boneskull
Copy link
Contributor

You can see the list of collaborators to this project via:

curl -i https://api.github.com/repos/visionmedia/mocha/collaborators

I don't know any way else to do it.

@travisjeffery
Copy link
Contributor

ya we have about a gazillion "maintainers" now. what matters is that mocha's going to be continued to be developed.

@jbnicolai
Copy link

Haha, hi @boneskull, and welcome 😄. Thanks for the cURL command to list people with push access, that's quite handy.

I suggest adding everyone with push access to the package.json for clarity, and as @travisjeffery said - the important thing is that we can now work through the backlog of issues :)

boneskull pushed a commit to boneskull/mocha that referenced this issue Jul 12, 2014
@okv
Copy link

okv commented Oct 22, 2014

+1 for that, @starsquare solution looks great

@boneskull boneskull added the type: feature enhancement proposal label Nov 7, 2014
dasilvacontin added a commit that referenced this issue Feb 3, 2015
Allow skip from test context for #332
@dasilvacontin
Copy link
Contributor

Closed by #946.

@ToshioMagic
Copy link

I'm still confused about this. I'm doing an API get, getting a 404, and then calling this.skip(). But when i call this.skip() I get an uncaught reference error to "this."

it looks like:

    beforeEach(function(done) {
        // blahblahblah
        this.skip();
        done();
    });

Also, I've never used github before so this may be in the wrong place....

@cmbuckley
Copy link
Contributor

@ToshioMagic This made it into the 2.2.0 release of mocha; what version are you using?

@ToshioMagic
Copy link

@cmbuckley 2.2.5

@cmbuckley
Copy link
Contributor

@ToshioMagic sounds like you're dealing with a separate problem, As the this.skip() functionality is available in your version. You may find more help on Gitter.

@ryan-shaw
Copy link

My test structure is defined inside a require module e.g.

define(function(require){
  before(function(){
    // do stuff
  });

  require('spec1');
  require('spec2');
  //etc
});

And in the specs there is something similar to

describe('Suite', function(){
  var enabled = false;
  before(function(){
    if(!loaded) return this.skip();
      // ...
  });

  it('should do something', function(){
    // ...
  });
});

From what I can tell if the module is not loaded it should skip the rest of suite but not skip the spec2, in my case it is skipping ALL tests after that suite. Is this by design?

@o0x2a
Copy link

o0x2a commented Nov 19, 2015

@ToshioMagic could you solved the problem? I have the same problem, when I use skip() inside a async callback I got following error from mocha.

 Error: the object {
  "message": [undefined]
  "uncaught": true
} was thrown, throw an Error :)
      at Runner.fail (\node_modules\mocha\lib\runner.js:225:11)
      at Runner.uncaught (\node_modules\mocha\lib\runner.js:682:8)
      at process.uncaught (\node_modules\mocha\lib\runner.js:727:10)

I'm using mocha v2.3.4 . can anyone confirm this problem? Should I open a new issue?

@danielstjules
Copy link
Contributor

@Code-guru skip within async code isn't yet supported, sorry! See #1618

@Himanshu11051
Copy link

That worked thanks. :)

@o0x2a
Copy link

o0x2a commented Nov 20, 2015

@danielstjules Thanks dan, I saw you had added the async skip to previous releases. But why it is not available in v2.3.4?

I think its use cases are very common. For example when you have an end2end system test, and need to check if the server is listening, and if it isn't, just skip the test.

Also since all network requests and database connections are aync in node.js, an async skip is a necessity, and not just a fancy feature.

@mmigdol
Copy link

mmigdol commented Sep 18, 2016

Async skip was added in #2335

@mrt123
Copy link

mrt123 commented Dec 2, 2016

as of mocha 3.2.0

  • this.skip() works in before or in it, but not inside describe
  • best option for conditionally skipping describe is this.pending = myCondition;
    ** however that does not seem to be part of your documented api.

And yes, for any doubters, the use case if very common:

  • using mocha to drive acceptance tests with selenium
  • application is build in test mode first and tested in test environment with limited features
  • then application is then progressed to next stage with more realistic / costly to build environment and full suite of features available (think large databases, added 3rd party providers , like payment processing etc).

@dasilvacontin
Copy link
Contributor

I agree functionality / methods should be consistent.

I wanted to point out that – as I got it – the outcome described in your use cases would be better addressed by the tagging feature (which is not there yet but): #1445.

@mrt123
Copy link

mrt123 commented Dec 2, 2016

@dasilvacontin Thanks, for making me aware of work being done on Tags.

However tags are inferior, to simply allowing a conditional. First of all, for most scenarios , they will force you to tag every single spec. Also you can imagine someone coming up with multiple tags just to describe few conditions. Allowing for conditionals is much more flexible.

Simply ensuring this.skip() works everywhere (describe, it , before etc) , and being able to provide optional skip reason, that would participate in output, would be the most flexible thing to do:
Simplest example:

if(myCondition) {
   this.skip('My reason for skipping');
}

Outputs :
- [Skip Reason: My reason for skipping. TEST LABEL: alert shows when leaving.

@dasilvacontin
Copy link
Contributor

dasilvacontin commented Dec 2, 2016

they will force you to tag every single spec

@mrt123 Wouldn't you have to add an if () { this.skip(...) to every spec otherwise?

// file1
describe('some class', function () {
  this.tag('integration', 'slow')
  ...
})

// file2
describe('some other class', function () {
  this.tag('integration', 'slow')
  ...
})

vs

// file1
const { isIntegration, isSlow } = require('./specUtils.js')

describe('some class', function () {
  if (isIntegration) this.skip('integration skip reason')
  if (isSlow) this.skip('slow skip reason')
  ...
})

// or
const { skipIfIntegration, skipIfSlow } = require('./specUtils.js')

describe('some class', function () {
  skipIfIntegration(this)
  skipIfSlow(this)
  ...
})

(since you probably want to reuse the condition across spec files, and maybe some of the skip messages)

If what you are concerned about is skip messages, that's a different improvement (feel free to open issue if there's none!), and nothing would stop you from using both tags and skip when there's a particular case where you want to skip + show a message.

@dasilvacontin
Copy link
Contributor

dasilvacontin commented Dec 2, 2016

To sum up, it feels like moving conditions from setup declarations to code inside tests. You would be able to have any conditions you want that generate options / set filter tags. Unless you don't plan on reusing them in multiple specs/tests, I don't see the benefit of having the conditions inside the spec/test itself. (and reusing them is the common case)

// setup.js
const mocha = require('mocha')

const tags = []
if (/* integration condition */) tags.push('integration')
if (/* slow condition */) tags.push('slow')
mocha.tags(tags)

@mrt123
Copy link

mrt123 commented Dec 2, 2016

@dasilvacontin Agreed, however still this.skip() currently (v3.2.0) does not work inside describe. And I don't see any other documented way.

@dasilvacontin
Copy link
Contributor

@mrt123 Yep, I'm aware of that sad fact. I was just replying to:

However tags are inferior, to simply allowing a conditional. First of all, for most scenarios , they will force you to tag every single spec. Also you can imagine someone coming up with multiple tags just to describe few conditions. Allowing for conditionals is much more flexible.

For now you can only conditionally declare the sub it/describes. If conditions are async, we have --delay.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type: feature enhancement proposal
Projects
None yet
Development

No branches or pull requests