Skip to content

Latest commit

 

History

History
114 lines (74 loc) · 5.64 KB

README.md

File metadata and controls

114 lines (74 loc) · 5.64 KB

MUBench Logo

MUBench : Review Site

Evaluating an API-misuse detector in MUBench requires manual reviews of (a subset of) the detector's findings on the benchmark projects. To facilitate these reviews, the MUBench Pipeline publishes detector findings to a review (web)site. See the review site of our TSE article 'A Systematic Evaluation of Static API-Misuse Detectors' for an example of such a site. To use MUBench, you need to either obtain an account for an existing review site or setup your own.

Setup

For testing purposes or private use, you may host a review site standalone using our Docker image. For hosting a public review site, we recommend installing the review-site application on a webserver of your choice.

On a Webserver

Webserver Requirements

  • PHP 7.x (for a list of the necessary PHP extensions, check our Dockerfile).
  • An SQL database and the respective PHP PDO extension (tested with SQLite and MySQL).

Setup Instructions

  1. Copy the review-site application from our Docker image:
    1. $> id=$(docker create svamann/mubench:stable)
    2. $> docker cp $id:/mubench/mubench.reviewsite - > reviewsite.tar
    3. $> docker rm -v $id
    4. Unpack the tar file on your machine.
  2. Copy settings.default.php to settings.php (override the existing file, which contains the configuration for running standalone within a Docker container).
  3. Adjust settings.php to your environment:
    • Enter your database-connection details below db.
    • Enter your site_base_url, e.g., /mubench
    • List your reviewer credentials below users.
  4. Upload the application to your webserver, e.g., http://your.site/mubench/.
  5. Grant the server read/write permissions on the upload and logs directories.
  6. Go to http://your.site/mubench/, which will initialize your database on the first visit.
  7. Delete the setup folder from your webserver.
  8. Publish misuse metadata, publish detector findings, and review detector findings.

Standalone

You may run a MUBench review site using our Docker container. Note, however, that this uses PHP's built-in webserver, which is not a full-featured webserver and discouraged for use on a public network.

  1. Run mubench> reviewsite start. To access the site from your host system, you need to forward port 80 from the shell to your host system, by adding -p 8080:80 to the Docker command running MUBench.
  2. Go to http://localhost:8080/, which will initialize your database on the first visit.
  3. Publish misuse metadata, publish detector findings, and review detector findings.

Check reviewsite -h for further details.

Hint: The standalone review site stores its database in the /mubench/findings/ folder, next to the detector findings captured from running API-misuse detectors.

Publish Misuse Metadata

To correctly display potential hits for known misuses from the dataset, the review site needs the misuse metadata, such as the description, the misuse location, and the misuse code. To upload the metadata to your review site run:

mubench> pipeline publish metadata -s http://your.site/mubench/ -u <RU> -p <RP>

Where

  • <RU> and <RP> are the username and password to access your review site with.

Check pipeline publish metadata -h for further details.

Hint: You may want to use the filter options (--datasets, --only, --skip) to upload metadata selectively.

Publish Detector Findings

To publish detector findings to your review site run:

mubench> pipeline publish <E> <D> -s http://your.site/mubench/ -u <RU> -p <RP>

Where

This will run the respective experiment, if you did not do so before.

Check pipeline publish -h for further details.

Hint: You may want to use the filter options (--datasets, --only, --skip, --limit) to upload findings selectively.

Known Issues

Cannot login as a reviewer

Scenario: You configured a user in your settings.php, but when you click Login and enter the credentials, the login prompt just reappears, as if you had typed in wrong credentials. This happens if your server is not forwarding the Basic Auth headers to the review-site application.

Solution: Try adding following line to the .htaccess file in the base directory of your MUBench review site:

RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization},L]

If this doesn't work, you may try to replace the entire contents of the .htaccess file with the following configuration that has been found to work on some servers (make sure to adjust the RewriteBase according to your setting):

RewriteEngine On
RewriteCond %{HTTP:Authorization} ^(.*)
RewriteRule .* - [e=HTTP_AUTHORIZATION:%1]
RewriteBase /mubench/
RewriteRule ^index\.php$ - [E=X-HTTP_AUTHORIZATION:%{HTTP:Authorization},QSA,L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . index.php [E=X-HTTP_AUTHORIZATION:%{HTTP:Authorization},QSA,L]