Blame script/test-leaks.pl

Packit bfcc33
#!/usr/bin/perl
Packit bfcc33
############################################################
Packit bfcc33
# this perl script is meant for developers only!
Packit bfcc33
# it will run all spec-tests (without verifying the
Packit bfcc33
# results) via valgrind to detect possible leaks.
Packit bfcc33
# expect that it takes 1h or more to finish!
Packit bfcc33
############################################################
Packit bfcc33
# Prerequisite install: `cpan Parallel::Runner`
Packit bfcc33
# You may also need to install `cpan File::Find`
Packit bfcc33
# You may also need to install `cpan IPC::Run3`
Packit bfcc33
############################################################
Packit bfcc33
# usage: `perl test-leaks.pl [threads]`
Packit bfcc33
# example: `time perl test-leaks.pl 4`
Packit bfcc33
############################################################
Packit bfcc33
# leaks will be reported in "mem-leaks.log"
Packit bfcc33
############################################################
Packit bfcc33
Packit bfcc33
use strict;
Packit bfcc33
use warnings;
Packit bfcc33
Packit bfcc33
############################################################
Packit bfcc33
# configurations (you may adjust)
Packit bfcc33
############################################################
Packit bfcc33
Packit bfcc33
# number of threads to use
Packit bfcc33
my $threads = $ARGV[0] || 8;
Packit bfcc33
Packit bfcc33
# the github repositories to checkout
Packit bfcc33
# if you need other branch, clone manually!
Packit bfcc33
my $sassc = "https://www.github.com/sass/sassc";
Packit bfcc33
my $specs = "https://www.github.com/sass/sass-spec";
Packit bfcc33
Packit bfcc33
############################################################
Packit bfcc33
# load modules
Packit bfcc33
############################################################
Packit bfcc33
Packit bfcc33
use IPC::Run3;
Packit bfcc33
use IO::Handle;
Packit bfcc33
use Fcntl qw(:flock);
Packit bfcc33
use File::Find::Rule;
Packit bfcc33
use Parallel::Runner;
Packit bfcc33
use List::Util qw(shuffle);
Packit bfcc33
Packit bfcc33
############################################################
Packit bfcc33
# check prerequisites
Packit bfcc33
############################################################
Packit bfcc33
Packit bfcc33
unless (-d "../sassc") {
Packit bfcc33
  warn "sassc folder not found\n";
Packit bfcc33
  warn "trying to checkout via git\n";
Packit bfcc33
  system("git", "clone", $sassc, "../sassc");
Packit bfcc33
  die "git command did not exit gracefully" if $?;
Packit bfcc33
}
Packit bfcc33
Packit bfcc33
unless (-d "../sass-spec") {
Packit bfcc33
  warn "sass-spec folder not found\n";
Packit bfcc33
  warn "trying to checkout via git\n";
Packit bfcc33
  system("git", "clone", $specs, "../sass-spec");
Packit bfcc33
  die "git command did not exit gracefully" if $?;
Packit bfcc33
}
Packit bfcc33
Packit bfcc33
unless (-f "../sassc/bin/sassc") {
Packit bfcc33
  warn "sassc executable not found\n";
Packit bfcc33
  warn "trying to compile via make\n";
Packit bfcc33
  system("make", "-C", "../sassc", "-j", $threads);
Packit bfcc33
  die "make command did not exit gracefully" if $?;
Packit bfcc33
}
Packit bfcc33
Packit bfcc33
############################################################
Packit bfcc33
# main runner code
Packit bfcc33
############################################################
Packit bfcc33
Packit bfcc33
my $root = "../sass-spec/spec";
Packit bfcc33
my @files = File::Find::Rule->file()
Packit bfcc33
            ->name('input.scss')->in($root);
Packit bfcc33
Packit bfcc33
open(my $leaks, ">", "mem-leaks.log");
Packit bfcc33
die "Cannot open log" unless $leaks;
Packit bfcc33
my $runner = Parallel::Runner->new($threads);
Packit bfcc33
die "Cannot start runner" unless $runner;
Packit bfcc33
Packit bfcc33
print "##########################\n";
Packit bfcc33
print "Testing $#files spec files\n";
Packit bfcc33
print "##########################\n";
Packit bfcc33
Packit bfcc33
foreach my $file (shuffle @files) {
Packit bfcc33
  $runner->run(sub {
Packit bfcc33
    $| = 1; select STDOUT;
Packit bfcc33
    my $cmd = sprintf('../sassc/bin/sassc %s', $file);
Packit bfcc33
    my $check = sprintf('valgrind --leak-check=yes %s', $cmd);
Packit bfcc33
    run3($check, undef, \ my $out, \ my $err);
Packit bfcc33
    if ($err =~ m/in use at exit: 0 bytes in 0 blocks/) {
Packit bfcc33
      print "."; # print success indicator
Packit bfcc33
    } else {
Packit bfcc33
      print "F"; # print error indicator
Packit bfcc33
      flock($leaks, LOCK_EX) or die "Cannot lock log";
Packit bfcc33
      $leaks->printflush("#" x 80, "\n", $err, "\n");
Packit bfcc33
      flock($leaks, LOCK_UN) or die "Cannot unlock log";
Packit bfcc33
    }
Packit bfcc33
  });
Packit bfcc33
}
Packit bfcc33
Packit bfcc33
$runner->finish;