Ejemplo n.º 1
0
def add_question():
    if current_user.user_type != 'admin':
        return abort(403)

    form = AddQuestionForm()
    if form.validate_on_submit():
        try:
            survey = ndb.Key(urlsafe=form.survey.data).get()
        except db.BadKeyError:
            survey = None

        if survey is None:
            return abort(400)

        question = Question(
            question=form.question.data,
            question_type=form.question_type.data,
            parent=survey.key,
            dimension=form.dimension.data,
            is_active=form.is_active.data,
            number=(Question.query(
                parent=survey.key).order(-Question.number).get().number) + 1)
        question.put()
        return redirect(url_for('home'))

    surveys = Survey.query()
    return render_template('add_question.haml', form=form, surveys=surveys)
Ejemplo n.º 2
0
 def test_get_survey(self):
     Question(question='What do?', number=1, question_type='closed',
              is_active=True).put()
     Question(question='Shouldn\'t show', number=2, question_type='closed',
              is_active=False).put()
     response = self.app.get('/survey')
     self.assertEqual(200, response.status_code)
     self.assertTrue('What do?' in response.data)
     self.assertFalse('Shouldn\'t show' in response.data)
Ejemplo n.º 3
0
 def __prepare_question_vote(self, username):
     with transaction.atomic():
         lecture = Lecture.objects.filter(hash='3j7t950').first()
         participant = Participant(username=username, public_nickname=username)
         participant.save()
         lecture.participants.add(participant)
         question = Question(text='How are you?', tags='hello', creator=participant, event=lecture)
         question.save()
         vote = QuestionVote(value=1, voter=participant, question=question)
         vote.save()
         lecture.save()
     return participant, lecture, question
Ejemplo n.º 4
0
 def create_questions(cls):
     users = LaskUser.objects.all()
     tags = Tag.objects.all()
     faker = Faker()
     for _ in range(QUESTIONS_COUNT):
         question = Question(
             title=faker.sentence(),
             text=faker.text(),
             question_author=random.choice(users),
             rating=random.randint(1, 100),
         )
         question.save()
         for _ in range(random.randint(1, 4)):
             question.tags.add(random.choice(tags))
     stdout_writer.stdout.write("Created test data: QUESTIONS")
Ejemplo n.º 5
0
def create_question():
    """ create new question using POSTed json
    """
    # parse POSTed json:
    question_created = request.get_json()
    error = True

    try:
        question = Question(**question_created)
        # insert:
        db.session.add(question)
        db.session.commit()
        error = False
    except:
        # rollback:
        db.session.rollback()
        error = True
    finally:
        db.session.close()

    if error:
        abort(500, description="Failed to create new Question")

    # format:
    response = jsonify({"success": True})
    return response, 201
Ejemplo n.º 6
0
def import_question_fixture(fixture):
    for question in fixture['data']:
        question_model = Question(question_title=question['question_title'])
        db.session.add(question_model)
        for answer in question['answers']:
            answer_model = Answer(answer_title=answer['answer_title'],
                                  correct=answer['correct'],
                                  question=question_model)
            db.session.add(answer_model)

    db.session.commit()
Ejemplo n.º 7
0
def create_exam():
    if request.method == 'POST':
        exam_payload = {}
        answer_ids = request.form.getlist('answer')
        question_ids = request.form.getlist('question')
        questions = Question.query.filter(Question.id.in_(question_ids)).all()
        for question in questions:
            exam_payload.update({
                question.id: {
                    'question': question.question_title,
                    'answers': {}
                }
            })
            for answer in question.answers:
                exam_payload[question.id]['answers'].update({
                    answer.id: {
                        'answer': answer.answer_title,
                        'correct': answer.correct,
                        'marked': str(answer.id) in answer_ids
                    }
                })
        exam_payload = pickle.dumps(exam_payload)
        # Save exam to database
        exam = Exam(user_id=current_user.id, result_payload=exam_payload)
        db.session.add(exam)
        db.session.commit()
        return redirect(url_for('exam_bp.view_exam', id=exam.id))

    questions_dict = {}
    questions_model = Question()
    # Check if database has less then 20 questions
    if questions_model.count_records() < 20:
        flash('Exam fail to start, there is less then 20 questions.', 'danger')
        return redirect(url_for('exam_bp.exam_list'))
    for i in range(20):
        questions = questions_model.random_questions()
        # This needs to be optimized it can create a lot of query
        while questions_dict.get(questions.id) is not None:
            questions = questions_model.random_questions()
        questions_dict.update({questions.id: questions})
    return render_template('create_exam.html', questions=questions_dict)
Ejemplo n.º 8
0
def create_question():
    form = QuestionForm()
    if form.validate_on_submit():
        question = Question(question_title=form.question_title.data)
        db.session.add(question)
        for entry in form.answers.entries:
            answer = Answer(answer_title=entry.data['answer_title'],
                            correct=entry.data['correct'],
                            question=question)
            db.session.add(answer)
        db.session.commit()
        flash('Question successfully added.', 'success')
        return redirect(url_for('exam_bp.question_list'))
    return render_template('create_question.html', form=form)
Ejemplo n.º 9
0
def faq_callback():
    form = QuestionForm()
    form_success = False
    items_list = Question.query.filter(Question.anwser.isnot(None)).all()
    if form.validate_on_submit():
        question = Question()
        form.populate_obj(question)
        db.session.add(question)
        db.session.commit()
        form_success = True
    return render_template('faq/root.html',
                           question_form=form,
                           items_list=items_list,
                           form_success=form_success)
Ejemplo n.º 10
0
def survey(course_key):
    try:
        course = ndb.Key(urlsafe=course_key).get()

    except db.BadKeyError:
        course = None

    if course is None:
        return abort(404)

    if request.method == 'POST':
        survey = StudentSurvey(parent=course.key, participant=current_user.key)
        survey.put()
        answers = []
        questions = ndb.get_multi(
            [ndb.Key(urlsafe=question) for question in request.form.keys()])
        for question, answer in zip(questions, request.form.values()):
            if question is None:
                continue

            if question.question_type == 'closed':
                answers.append(
                    Answer(question=question.key,
                           int_value=int(answer),
                           parent=survey.key))

            else:
                answers.append(
                    Answer(question=question.key,
                           string_value=answer,
                           parent=survey.key))

        ndb.put_multi(answers)
        deferred.defer(_send_to_keen, survey.key, course.key,
                       [answer.key for answer in answers])
        return redirect(url_for('home'))

    questions = Question.get_active().fetch()

    numbering = 0
    dimension_check = ''
    for question in questions:
        if dimension_check != question.dimension:
            numbering += 1
            dimension_check = question.dimension
        question.dimension = str(numbering) + question.dimension

    return render_template('survey.haml', questions=questions, course=course)
Ejemplo n.º 11
0
def askQuestion():
    if request.form:
        if current_user.is_anonymous:
            flash('You have to login to post questions', 'info')
            return redirect(url_for('main.home'))
        else:

            userQuestion = request.form.get('question')
            questionTag = request.form.get('tags')
            question = Question(content=userQuestion,
                                tags=questionTag,
                                askerId=current_user.id)

            db.session.add(question)
            db.session.commit()
            return redirect(url_for('main.home'))
Ejemplo n.º 12
0
def analysis(class_key):
    try:
        class_ = ndb.Key(urlsafe=class_key).get()

    except db.BadKeyError:
        class_ = None

    if class_ is None:
        return abort(404)

    course = class_.course.get()
    lecturer = class_.lecturer.get()
    surveys = StudentSurvey.query(ancestor=class_.key)
    return render_template('analysis.haml',
                           surveys=surveys,
                           course=course,
                           lecturer=lecturer,
                           class_key=class_key,
                           questions=Question.get_active())
Ejemplo n.º 13
0
def query():
    final_filter = []
    """Custom queries using keen.io as a backend.
    The frontent form must pass values in using the names
        `property_name` - The name of the property you wish to query
        `property_value` - The value of the property being entered
        `operator` - 'eq', 'gt', 'lt'
    """
    if current_user.user_type != 'admin':
        return 403

    if request.method == 'POST':
        # Run the query

        # Used to display the query filters on the view.
        filter_view = [request.form.to_dict()]

        number_of_filters = len(request.form) / 3
        for filter_number in range(0, number_of_filters):
            temp = {}
            temp['operator'] = request.form["operator" + str(filter_number)]
            temp['property_value'] = request.form["property_value" +
                                                  str(filter_number)]
            temp['property_name'] = request.form["property_name" +
                                                 str(filter_number)]
            final_filter.append(temp)

        response = keen.extraction('answers', filters=final_filter)
        if len(response) == 0:
            response = 'No results found'

        final_filter = json.dumps(final_filter)
        # response = json.dumps(response, indent=2, sort_keys=True)
        return render_template('custom_analysis.haml',
                               filters=final_filter,
                               questions=Question.get_active(),
                               filter_view=filter_view,
                               number_of_filters=number_of_filters,
                               response=response)

    return 'Why'
Ejemplo n.º 14
0
    def create_question(self, data):
        if (data.get('id', None) is None) or (data.get('id') == 0):
            question = Question()
            question.text_en = data.get('text_en', '')
            question.text_ru = data.get('text_ru', '')
            question.approved = data.get('approved', False)
            question.image_name = data.get('image_name', '')
            theme = data.get('theme', None)
            if isinstance(theme, Theme):
                question.theme = theme
            else:
                print 'theme for question {} not setted'.format(
                    question.__repr__())

            for aDict in data.get('answers'):
                a = Answer()
                a.text_en = aDict.get('text_en', '')
                a.text_ru = aDict.get('text_ru', '')
                a.is_correct = aDict.get('is_correct')
                question.answers.append(a)
                # chech if answer.question_id will fill after session.commit()
        else:
            question = Question.query.get(data['id'])
        return question
Ejemplo n.º 15
0
 def test_post_survey(self):
     question_key = Question(question='What do?', number=1, question_type='closed',
                             is_active=True).put()
     response = self.app.post('/survey', data={question_key.urlsafe(): 4})
     self.assertEqual(302, response.status_code)
     self.assertEqual(1, Answer.query().count())
Ejemplo n.º 16
0
def populate():
    import datetime
    admin = User.create('admin', 'password', 'admin')
    admin.put()

    principal_user = User.create('principal', 'password', 'lecturer')
    principal = Lecturer(name='Principal', title='Dr', user=principal_user.key)
    principal.put()

    school = School(name='University of The West Indies - Mona',
                    principal=principal.key)
    school.put()

    hof_user1 = User.create('hof1', 'password', 'lecturer')
    hof_user2 = User.create('hof2', 'password', 'lecturer')
    hof1 = Lecturer(name='Head Of Pure and Applied',
                    title='Dr',
                    user=hof_user1.key)
    hof2 = Lecturer(name='Head Of Medical Sciences',
                    title='Dr',
                    user=hof_user2.key)
    hof1.put()
    hof2.put()

    faculty1 = Faculty(name='Pure and Applied Science',
                       school=school.key,
                       head_of_faculty=hof1.key)
    faculty2 = Faculty(name='Medical Sciences',
                       school=school.key,
                       head_of_faculty=hof2.key)
    faculty1.put()
    faculty2.put()

    hod_user1 = User.create('hod1', 'password', 'lecturer')
    hod_user2 = User.create('hod2', 'password', 'lecturer')
    hod_user3 = User.create('hod3', 'password', 'lecturer')
    hod_user4 = User.create('hod4', 'password', 'lecturer')
    hod1 = Lecturer(name='Head Of Computing', title='Dr', user=hod_user1.key)
    hod2 = Lecturer(name='Head Of Mathematics', title='Dr', user=hod_user2.key)
    hod3 = Lecturer(name='Head Of Medicine', title='Dr', user=hod_user3.key)
    hod4 = Lecturer(name='Head Of Microbiology',
                    title='Dr',
                    user=hod_user4.key)
    hod1.put()
    hod2.put()
    hod3.put()
    hod4.put()

    department1 = Department(name='Computing',
                             faculty=faculty1.key,
                             head_of_department=hod1.key)
    department2 = Department(name='Mathematics',
                             faculty=faculty1.key,
                             head_of_department=hod2.key)
    department3 = Department(name='Medicine',
                             faculty=faculty2.key,
                             head_of_department=hod3.key)
    department4 = Department(name='Microbiology',
                             faculty=faculty2.key,
                             head_of_department=hod4.key)
    department1.put()
    department2.put()
    department3.put()
    department4.put()

    principal.department = department4.key
    hof1.department = department2.key
    hof2.department = department3.key
    hod1.department = department1.key
    hod2.department = department2.key
    hod3.department = department3.key
    hod4.department = department4.key
    principal.put()
    hof1.put()
    hof2.put()
    hod1.put()
    hod2.put()
    hod3.put()
    hod4.put()

    student_user = User.create('student', 'password', 'student')
    student = Student(name='Kevin Leyow',
                      email_address='*****@*****.**',
                      user=student_user.key,
                      dob=datetime.date(year=1992, month=4, day=12),
                      year=3,
                      status='FT',
                      gender='M')

    lecturer_user = User.create('lecturer', 'password', 'lecturer')
    lecturer = Lecturer(name='Jimmy',
                        title='Dr',
                        user=lecturer_user.key,
                        department=department1.key)

    course = Course(name='Database Management Systems',
                    code='COMP3161',
                    total_students=90,
                    department=department1.key,
                    faculty=faculty1.key)
    course2 = Course(name='Theory Of Computation',
                     code='COMP3702',
                     total_students=20,
                     department=department1.key,
                     faculty=faculty1.key)

    ndb.put_multi([lecturer, course])
    ndb.put_multi([lecturer, course2])

    class_ = Class(course=course.key, lecturer=lecturer.key)
    class2_ = Class(course=course2.key, lecturer=lecturer.key)
    class_.put()
    class2_.put()

    student.courses = [class_.key, class2_.key]
    lecturer.courses = [class_.key, class2_.key]
    ndb.put_multi([student, lecturer])

    survey = Survey(title='General survey', description='A general survey')
    survey_key = survey.put()

    with open('application/questions.txt') as f:
        questions = []
        for number, line in enumerate(f.readlines()):
            question_type, dimension, question = line.split('|')
            questions.append(
                Question(question_type=question_type,
                         dimension=dimension,
                         question=question,
                         is_active=True,
                         number=number + 1,
                         parent=survey_key))
    ndb.put_multi(questions)
    return 'Done.'
Ejemplo n.º 17
0
import csv
from application import db
from application.models import Question, Test
import pandas as pd

csv_path = './RandDtest.csv'

data = pd.read_csv(csv_path)
data.columns = ['question', 'answer']

questions = []

for index, row in data.iterrows():
    question = Question(question=row[0], answer=row[1])
    questions.append(question)

test = Test(questions=questions)
db.session.add(test)
db.session.commit()

#for index, row in data.iterrows():
#answer =Answers(answer=row[1])
#db.session.add(answer)
# db.session.commit()
Ejemplo n.º 18
0
 def test_question_can_vote_2(self):
     participant = Participant.objects.create(username='******')
     lecture = Lecture.objects.get(hash='3j7t950')
     question = Question(text='How are you?', tags='hello', creator=participant, event=lecture)
     question.save()
     self.assertTrue(question.can_vote(participant))