Skip to content

Latest commit

 

History

History
executable file
·
114 lines (85 loc) · 4.5 KB

README.md

File metadata and controls

executable file
·
114 lines (85 loc) · 4.5 KB

alt text

A system to automate part of the collaborative ontology development process. Given a repository with an owl file, OnToology will survey it and produce diagrams, a complete documentation and validation based on common pitfalls.

Creator: Ahmad Alobaid

Contributors: Daniel Garijo, Oscar Corcho, Maria Poveda

###Project Plan

  • Provide a better solution for handling private and public repos.
  • Docker setup
  • Use front-end framework (e.g. AngularJS)
  • Add new features (e.g. integrate with GitLab)
  • Deploy on the live server (now on a testing server)
  • Prepare automated testing

###What the system does now:

###How to use it

  1. From the website, you only have to put the repo as user/repo i.e. myuser/myrepo (now it doesnot work with organization, for more technical info please refere to the issues section).
  2. Update/create auton.cfg (will use default configurations otherwise)
  3. Update your repo and push.
  4. Go to your repo setting -> webhooks and service and you will see the webhook. you can also click on the webhook link to see the request sent and the server replies.
  5. If pull requests are created successfully you can find them in the pull requests pool.

Please only use this with testing repos

used python libraries:

###Install the libraries using pip

pip install -r requirements.txt

Note: you must navigate to the requirements.txt using the "cd" command

rdfxml (can be downloaded from http://infomesh.net/2003/rdfparser/) note: I modified rdfxml to return a dictionary rather than a string, to see the modification go the rdfxml.py file you will see the original Sink commented out and right beneath it is my Sink function

To install pip follow the instructions here https://pip.pypa.io/en/latest/installing.html

##Working with Multiple ssh keys At some point, you may need to perform tests locally (django tests), you may need to have multiple ssh keys for github at the same time. If so there is good example on how to do them http://techamad.blogspot.com.es/2015/05/github-with-multiple-keys.html or https://gist.github.com/jexchan/2351996

##Take a peek on the system

##Tests

ID Test Case Expected Result Status
1 Adding non-existing repo shouldn't add the non-existing repo and should add an error page ✔️
2 Very large ontology To show error message ⚠️ (takes literally days to perform the test, we are going to ignore this)
3 Ontology with syntax error To show error message
4 If a tool is not able to generate an output should not stop, should proceed with the other tools
5 Add a new repo should be added
6 Adding a repo that already added should be accepted
7 Add a new repo, then delete this repo from github and try to do some actions e.g. generate previsualization should run the action without problems
8 Generate previsualization should be regenerated
Sign Meaning
Test automation is not implemented
✔️ Test automation is completed
⚠️ Warning

##How to deploy the on your server (To be written later) ####Environment variables that need to be set

export github_username=xxxxxx
export github_password=xxxxxxx
export github_repos_dir=/xxx/xxx/xxx/temp/
export ar2dtool_dir=/xxxx/xxxx/xxxx/xxx/ar2dtool/bin/
export ar2dtool_config=/xxxx/xxxx/xxxx/config/
export widoco_dir=/xxxxx/xxxx/xxxx/Widoco/JAR/
export OnToology_home=True
export SECRET_KEY=xxxxxxxxxxxxxxxxxxxxxxxxxxxx
export user_github_username=xxx@xxxxx.xxx
export user_github_password=xxxxxx
export test_repo=xxx/xxx
export test_folder=xxx/xxx/xxx
export test_ont_hl=xxx/xxx
export test_ont_nl=xxx/xxx
export tests_ssh_key=/xxx/.xxx/id_rsa_xxx
export test_github_username=xxx@xxx.xxx
export test_github_password=xxx