这个样本系统是基于国科大研究生课程 (高级软件工程) 开发的项目,目的是帮助入门者学习RoR (Ruby on Rails)
适合新学者的入手的第一个项目 (演示Demo戳这里),入门者可以在这个样本系统上增加更多的功能:
- 处理选课冲突、控制选课人数
- 统计选课学分,学位课等
- 增加选课的开放、关闭功能
- 自定义管理员后台
- 基于OAuth的授权登陆
- Excel格式的数据导入
- 绑定用户邮箱(实现注册激活,忘记密码等)
- 站内查找检索 (课程按分类查找,过滤等)
- 多角色登陆(学生,老师,管理员)
- 学生动态选课,退课
- 老师动态增加,删除课程
- 老师对课程下的学生添加、修改成绩
- 权限控制:老师和学生只能看到自己相关课程信息
目前使用的库和数据库:
- 使用Bootstrap作为前端库
- 使用Rails_admin Gem作为后台管理
- 使用Postgresql作为数据库
使用前需要安装Bundler,Gem,Ruby,Rails等依赖环境。
请根据本地系统下载安装postgresql数据库,并运行psql -h localhost
检查安装情况。
在终端(MacOS或Linux)中执行以下代码
$ git clone https://github.com/PENGZhaoqing/CourseSelect
$ cd CourseSelect
$ bundle install
$ rake db:migrate
$ rake db:seed
$ rails s
在浏览器中输入localhost:3000
访问主页
##使用
1.学生登陆:
密码:password
2.老师登陆:
密码:password
3.管理员登陆:
密码:password
账号中数字都可以替换成2,3...等等
项目可直接在Heroku上免费部署
1.fork此项目到自己Github账号下
2.创建Heroku账号以及Heroku app
3.将Heroku app与自己Github下的fork的项目进行连接
4.下载配置Heroku CLI命令行工具
5.运行heroku login
在终端登陆,检查与heroku app的远程连接情况git config --list | grep heroku
,若未检查到相应的app,请看这里
6.运行部署,详情请戳这里
本项目包含了部分的测试(integration/fixture/model test),测试文件位于/test目录下。运行测试:
PENG-MacBook-Pro:IMS_sample PENG-mac$ rake test
Run options: --seed 15794
# Running:
.........
Finished in 1.202169s, 7.4865 runs/s, 16.6366 assertions/s.
9 runs, 20 assertions, 0 failures, 0 errors, 0 skips
先fork此项目,在分支修改后,pull request到主分支
提问请到issues里创建,欢迎contributor!
如果觉得好,给项目点颗星吧~
1)获取源码分支 首先登录github网站fork https://github.com/liuqiaoping7/CourseSelect.git。 本地git clone https://github.com/自己的用户名/CourseSelect.git,或者直接C9以此建立工程。
2)本地编辑,push代码到自己的fork分支 git add --all git commit -m "application for.." git push origin master
3)分支同步
(1).组员push request之前,需要先从组代码pull最新的代码并合并测试通过:
常用几条命令:
git remote add upstream https://github.com/liuqiaoping7/CourseSelect.git (添加组内公共源)
git remote -v (查看是否添加成功)
git checkout -b source (新建一个分支,名称任意)
git pull upstream master (分支与组内源同步)
git checkout master (回到master分支)
git merge source (合并source到master分支,merge只解决文件内容合并,自动合并冲突部分手动修改,逻辑冲突部分测试后发现)
git add * (若有手动修改,需要添加到工作区)
git commit -m "merge for.." (若有手动修改,生成新的节点)
git push origin master (提交到github)
(2).发起pull request,在github上网页操作。
(3).组长merge组员的贡献到origin/master。
4)回退操作 git reset --hard HEAD (恢复到最近一次提交) git checkout -- file (或者丢弃单个文件修改就是) git clean -dxf (则会丢弃所以没有add的修改,保持工作区的清净)
基本上这些命令就差不多够了. 如果希望系统了解git,可看看廖雪峰的教程:百度网盘 http://pan.baidu.com/s/1eSkHTrc 提取码 dagu.