I have created some unit tests for my firebase security rules. Part of this testing is trying to do illegal operations and asserting that they fail.
My problem has to do with noise; when I run the tests using nodeunit, the firebase client spits out several logs similar to this:
FIREBASE WARNING: set at /user failed: permission_denied
I do not want this output when intentionally doing illegal operations as it just results in noise and confusion.
Firebase provides tools for tracking analytics, reporting and fixing app crashes, creating marketing and product experiment. Firebase offers a number of services, including: Analytics – Google Analytics for Firebase offers free, unlimited reporting on as many as 500 separate events.
In our testing suite, we rewrite process.stderr.write to only ignore firebase warnings like so:
Javascript
process.stderr.write = (function(write) {
  return function() {
    if (!arguments[0].includes("FIREBASE WARNING"))
      write.apply(process.stderr, arguments);
  };
}(process.stderr.write));
Typescript (including tslint fix)
process.stderr.write = (() => {
    // tslint:disable-next-line:no-unbound-method
    const write = process.stderr.write;
    return function () {
        if (!(arguments[0] as string).includes("FIREBASE WARNING")) {
            return write.apply(process.stderr, arguments);
        }
    };
})();
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With