Skip to content

A Vue app that uses the genderbias python package to detect gender bias in writing.

Notifications You must be signed in to change notification settings

glam-lab/reading-for-genderbias-web

 
 

Repository files navigation

Reading For Gender Bias - Web front end

Table of contents

Introduction

This project is a web-based user interface for Reading for Gender Bias. This project is currently under active development by members of GLAM Lab at Whitman College.

Technologies

Installation and Usage

To install the back-end

git clone https://github.com/gender-bias/gender-bias
cd gender-bias
pip3 install -e .

NOTE: The last line in the above snippet installs this library in "editable" mode, which is probably fine while the library is in a state of flux.

To install packages

To set up the project, make sure yarn is installed and then use it to install the packages for this project:

yarn install

To run the front-end server

Once installed, run the front-end server as follows:

yarn serve 

The server runs at http://localhost:8080 by default.

To run tests

Before running tests, start the back-end server with genderbias-server, or start a fake server with yarn test-serve.

To run the entire test suite, run yarn test.

To run a single test, run yarn test --grep 'test name', specifying the name of the test you wish to run.

You can find the tests in the test directory. The Component.spec.js files depend on bootstrap.js.

To write tests

The tests are divided into files by Vue component.

They employ the Mocha test framework and the Puppeteer and Chai libraries. Puppeteer allows one to simulate user events in the browser and Chai is an assertion library.

When you create a .spec.js test file, it will be called by bootstrap.js when you run the tests.

In the test files, describe blocks demarcate the tests by state, such as the page after the opening of the page, the clicking of a button, the typing of text into the textarea, or hovering over a style class. These state-changing events are handled with before and after blocks.

The tests run asynchronously, which is indicated by the async and await keywords. This is because we don't know how long each test will take to complete, so it is more efficient for them to run concurrently. The await keyword tells the line to run only after the previous asynchronous work within the function has finished running, and can only be used in functions that are prefaced with async.

The convention is to define variables for style-class-selectors necessary for testing in bootstrap.js; again, these are organized by component.

To lint and fix files

Run

yarn lint

Contributors

  • Mollie Marr @molliem conceived the project and guided its developement.
  • Jordan Matlesky @j6k4m8 started the project and mentored the GLAM team.
  • Janet Davis @ProfJanetDavis (Mentor for the GLAMLab Developers, summer 2020)
  • Ahmed Elsayed @elsayeaa (Main Developer, summer 2020)
  • Dylan Wu @dylanjwu (Main Developer, summer 2020)
  • Kalilou Ali Kadiri @kaliloua7 (Main Developer, summer 2020)
  • Nidhi Jaltare @nidhi2509 (Main Developer, summer 2020)
  • Zoë Hill @Life1999 (Main Developer, summer 2020)

About

A Vue app that uses the genderbias python package to detect gender bias in writing.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Vue 55.7%
  • JavaScript 41.3%
  • HTML 3.0%