Pythy is a web-based programming environment for Python that
eliminates software-related barriers to entry for
novice programmers, such as installing the language runtime and IDE
and properly configuring other dependencies. Within seconds, students can
begin writing code, watch it execute, debug it, and access support materials and tutorials,
all from within the familiar context of their web browser.
For more information please see the slides and the paper
- Ruby
- The Ruby on Rails framework.
- Mysql client and server. (For linux install the dev packages also.)
- A JavaScript runtime (Ex: Node.js)
- The Redis server.
- The lame mp3 encoder.
- Pillow - The Python Imaging Library Fork for server side image processing.
- The wave module for server side sound processing.
- Imagemagick.
(For an ubuntu installation see Setup Ruby on Rails on Ubuntu)
- Clone the git repository.
git clone https://github.com/web-cat/pythy.git
- Go into the newly created pythy directory.
cd pythy
- Install the dependencies.
bundle install
andnpm install
- Create a database configuration file at
config/database.yml
. The adapter must be mysql2 as some of the sql statements will not work otherwise. Sample configuration file. - Create the database.
bundle exec rake db:create
- Load the schema into the database.
bundle exec rake db:schema:load
- Seed the database with the initial values.
bundle exec rake db:seed
- Run the server.
rails server
- If the server is running locally, visit http://localhost:3000, else, visit the corresponding url.
- To be able to use the grading feature, you need to have
sidekiq running on the server.
bundle exec sidekiq
. The sidekiq dashboard can be accessed at /sidekiq. - Start the juggernaut server by running
./node_modules/juggernaut/server.js
The tests are located in the spec
directory. To run them, first prepare the
test database by running the commands
bundle exec rake db:test:prepare
bundle exec rake db:seed RAILS_ENV=test
Preparing the test database is a one-time operation.
Now, the tests can be run using the command
bundle exec rspec
Running the tests generates a coverage report
(using simplecov)
that is stored in the coverage
directory.
Open the index.html
file in a web browser to view the test coverage.
development:
adapter: mysql2
encoding: utf8
database: dev_pythy
pool: 5
username: <your mysql username>
password: <your mysql password>
test:
adapter: mysql2
encoding: utf8
database: test_pythy
pool: 5
username: <your mysql username>
password: <your mysql password>
- Design as a modern, AJAX-powered Web 2.0 application.
- Avoid duplicating the traditional IDE model of a project tree, overfull toolbars, and multiple docked views. Instead, take advantage of the existing web browser document and tab model that students are already accustomed to.
- Store student code in Git repositories; adopt an aggressive auto-saving policy to collect fine-grained data about novices' programming habits and to avoid data loss.
- Evaluate Javascript-based Python implementations (Skulpt, Pyjs, Pyjaco, others?) to compile/run/debug code entirely on the client, eliminating server-round-trip latency—also to enable highly interactive/graphical assignments that render live in the browser; consider supporting server-side Python/Jython as well.
- Explore integrating an open-source interactive textbook directly into the application, such as How to Think Like a Computer Scientist: Interactive Edition (Using Pyth on 3.x) (which already uses Skulpt to run the embedded exercises).
We would like to acknowledge those who have graciously provided funding for our initial work on Pythy—the SIGCSE Special Projects Grants board, which provided undergraduate student wages support for Pythy's initial development, and the Virginia Tech Student Engineering Council, which provided support for purchasing the server hardware for Pythy's deployment at Virginia Tech.