コード例 #1
0
    def _create_user(self, data):
        username = self._find_available_username(data)

        first_name = data.get('first_name')
        last_name = data.get('last_name')
        facebook_uid = data.get('uid')
        img_url = data.get('pic_square')

        email = '%s@facebookuser.%s.com' % (first_name, settings.SITE_NAME)

        user = User(username=username,
                    email=email,
                    first_name=first_name,
                    last_name=last_name)
        temp_password = User.objects.make_random_password(length=24)
        user.set_password(temp_password)
        user.save()

        if img_url:
            img = ContentFile(requests.get(img_url).content)
            name = img_url.split('/')[-1]
            user.picture.save(name, img, False)

        FacebookAccount.objects.create(uid=facebook_uid,
                                       user=user,
                                       avatar=img_url)

        return user
コード例 #2
0
    def setUpClass(cls):
        super().setUpClass()
        session = cls.Session()
        cls.username = '******'
        cls.password = '******'
        user = User(username=cls.username,
                    password=str(
                        bcrypt.hashpw(cls.password.encode('utf-8'),
                                      bcrypt.gensalt()), 'utf-8'),
                    avatar='Katarina.png',
                    introduction='L')
        article = Article(
            user=user,
            title='L',
            introduction='L',
            markdown_content='L',
            compiled_content='L',
        )
        tag = Tag(content='hello')
        article.tag.append(tag)
        user.tag.append(tag)
        session.add(user)
        session.add(article)

        fish_record = Record(
            title='hello',
            content=['hello'],
            image_num=1,
            source='hello',
        )
        session.add(fish_record)
        session.commit()
        session.close()
コード例 #3
0
ファイル: tests.py プロジェクト: zjjott/html
    def setUp(self):  # mock需要登录的基类函数,统一返回测试用户
        if self.contexts is None:
            self.contexts = []
        super(LoginTestCase, self).setUp()
        user = User(
            username="******",
            tenant_id="mt_tenant_1",
            user_id="mt_user_1",
        )
        user.save_object()
        user_id = user.id

        def get_current_user():
            raise NotImplementedError("这个方法不应该被调用,参考get_current_user_async方法")
            # return User.query().get(user_id)  # bind session

        o = patch.object(UserAuthBaseHandle,
                         'get_current_user',
                         side_effect=get_current_user)

        @coroutine
        def get_current_user_async():
            user = User.query().get(user_id)
            raise Return(user)

        o = patch.object(UserAuthBaseHandle,
                         'get_current_user_async',
                         side_effect=get_current_user_async)
        self.contexts.append(o)
        o.__enter__()
コード例 #4
0
ファイル: cmd.py プロジェクト: kirimaks/travel_website
    def run(self):
        print("Create admin")

        from apps.auth.models import User
        admin = User(username="******", password="******",
                     email="*****@*****.**",
                     confirmed=True)
        db.session.add(admin)
        db.session.commit()
コード例 #5
0
ファイル: test_users.py プロジェクト: kirimaks/travel_website
    def test_create_users(self):
        for _ in range(users_number):

            username = "******".format(faker.user_name(), str(randrange(0, 99)))
            email = "{}{}".format(str(randrange(0, 99)), faker.email())

            user = User(username=username,
                        password=faker.password(),
                        email=email)
            db.session.add(user)
        db.session.commit()
コード例 #6
0
ファイル: tests.py プロジェクト: zjjott/html
 def test_picker(self):
     User(username="******", tenant_id="mt_tenant_1",
          user_id="mt_user_1").save_object()
     user = User.query().first()
     # have not error
     dumped_user = user.dumps()
     loaded_user = User.loads(dumped_user)
     self.assertEqual(loaded_user.username, user.username)
     self.assertEqual(loaded_user.tenant_id, user.tenant_id)
     self.assertEqual(loaded_user.user_id, user.user_id)
     self.assertEqual(loaded_user.id, user.id)
     self.assertEqual(loaded_user.updated_at, user.updated_at)
コード例 #7
0
ファイル: tests.py プロジェクト: zjjott/html
 def test_getattr(self):
     user = User(
         username="******",
         tenant_id="mt_tenant_1",
         user_id="mt_user_1",
     )
     user.save_object()
     self.assertEqual(User.query(User).count(), 1)
     first_user = User.query(User).one()
     self.assertEqual(first_user['username'], "test")
     first_user['username'] = "******"
     self.assertEqual(first_user.username, "test2")
     User.save_updates(first_user)
コード例 #8
0
ファイル: tests.py プロジェクト: zjjott/html
 def test_iter(self):
     user = User(
         username="******",
         tenant_id="mt_tenant_1",
         user_id="mt_user_1",
     )
     user.save_object()
     for i, value in user:
         pass
     obj = user.items()
     keys = user.keys()
     values = user.values()
     self.assertEqual(keys, [o[0] for o in obj])
     self.assertEqual(values, [o[1] for o in obj])
コード例 #9
0
ファイル: views.py プロジェクト: kirimaks/travel_website
def register():
    form = RegisterForm()
    if form.validate_on_submit():
        user = User(email=form.email.data,
                    username=form.username.data,
                    password=form.password.data)
        db.session.add(user)
        db.session.commit()

        token = user.generate_confirmation_token()
        send_email(user.email,
                   "Confir your account",
                   template="confirm",
                   token=token)

        flash('Confirmation token has been sent to your email.')
        return redirect(url_for('index'))
    return render_template("register.html", form=form)
コード例 #10
0
ファイル: tests.py プロジェクト: zjjott/html
 def test_todict(self):
     user = User(
         username="******",
         tenant_id="mt_tenant_1",
         user_id="mt_user_1",
     )
     user.save_object()
     self.assertEqual(User.query(User).count(), 1)
     first_user = User.query(User).one()
     self.assertIsNone(first_user.deleted_at)
     expect = {
         'username': u'test',
         'user_id': u'mt_user_1',
         'tenant_id': u'mt_tenant_1',
         u'deleted_at': None,
         'id': 1
     }
     user_obj = first_user.to_dict()
     for key, value in expect.iteritems():
         self.assertEqual(user_obj[key], value)
コード例 #11
0
ファイル: tests.py プロジェクト: zjjott/html
 def test_create(self):
     self.assertEqual(User.query(User.id).count(), 0)
     user = User(
         username="******",
         tenant_id="mt_tenant_1",
         user_id="mt_user_1",
     )
     user.save_object()
     self.assertEqual(User.query(User).count(), 1)
     first_user = User.query(User).one()
     self.assertEqual(first_user.username, "test")
     self.assertEqual(first_user.tenant_id, "mt_tenant_1")
     self.assertEqual(first_user.user_id, "mt_user_1")
     yield gen.sleep(1)
     first_user.username = '******'
     # first_user.updated_at = datetime(2010, 1, 1,tzinfo=UTC)
     first_user.save_object()
     self.assertEqual(User.query(User).count(), 1)
     first_user = User.query(User).one()
     self.assertGreater(first_user.updated_at, first_user.created_at)
     # first_user.updated_at = datetime(2010, 1, 1, tzinfo=UTC)
     # first_user.save_object()
     first_user = User.query(User).first()
コード例 #12
0
    def _create_user(self, access_token, data):
        username = self._find_available_username(data)

        twitter_username = data.screen_name
        first_name, last_name = self._get_first_last_name(data)
        avatar = data.profile_image_url

        email = '%s@twitteruser.%s.com' % (twitter_username,
                                           settings.SITE_NAME)

        user = User(username=username,
                    email=email,
                    first_name=first_name,
                    last_name=last_name)
        temp_password = User.objects.make_random_password(length=24)
        user.set_password(temp_password)
        user.save()

        TwitterAccount.objects.create(user=user,
                                      username=twitter_username,
                                      access_token=access_token.key,
                                      avatar=avatar)

        return user
コード例 #13
0
def register():
    error = None
    if request.method == 'POST':
        db.create_all()
        if request.form['password1'] != request.form['password2']:
            error = '两次密码不相同!'
        elif valid_register(request.form['username'], request.form['email']):
            user = User(username=request.form['username'],
                        password=my_md5(request.form['password1']),
                        email=request.form['email'])
            db.session.add(user)
            db.session.commit()
            token = user.generate_activate_token()
            send_activate_mail(user.email,
                               '账号激活',
                               'activate',
                               username=user.username,
                               token=token)
            flash("成功注册,请移步至邮箱点击激活")
            return redirect(url_for('user.home'))
        else:
            error = '该用户名或邮箱已被注册!'

    return render_template('login/register.html', error=error)
コード例 #14
0
    def test_email_diff_subtitles(self):
        initial_count = len(mail.outbox)
        # set a user who can receive notification
        # make sure we have a different author, else he won't get notified
        author = User(username='******',
                      email='*****@*****.**',
                      notify_by_email=True,
                      valid_email=True)
        author.save(send_email_confirmation=False)
        # bypass logic from hell
        author.valid_email = True
        author.save()

        # this is needed for the non_editor template check
        user2 = User(username='******',
                     email='*****@*****.**',
                     notify_by_email=True,
                     valid_email=True)
        user2.save(send_email_confirmation=False)
        # bypass logic from hell
        user2.valid_email = True
        user2.save()
        # version is indentical to previous one
        video = Video.get_or_create_for_url(
            "http://wwww.example.com/video-diff.mp4")[0]
        video.followers.add(author)
        video.followers.add(user2)

        language = SubtitleLanguage(video=video, language_code='en')
        language.save()
        subs_data = [
            [0, 1000, '1'],
            [1000, 2000, '2'],
        ]

        subtitles_1 = SubtitleSet.from_list('en', subs_data)
        old_version = language.add_version(subtitles=subtitles_1,
                                           author=author)

        # now we change the text on the second sub
        subs_data[1][2] = '2 changed'
        # add a regular sub
        subs_data.append([2000, 3000, 'new sub'])
        # add an unsyced
        subs_data.append([None, None, 'no sync'])
        subtitles_2 = SubtitleSet.from_list('en', subs_data)
        new_version = language.add_version(subtitles=subtitles_2)
        self.assertTrue(len(video.notification_list()) > 0)

        res = send_new_version_notification(new_version.pk)
        self.assertNotEqual(res, None)
        # we expect two emails, one is the new-edits-non-editor, and
        # the other for mail_notification.html
        self.assertEqual(len(mail.outbox), initial_count + 2)
        for email_number, email_msg in enumerate(mail.outbox):
            # make sure this is the right message
            self.assertIn("New edits to ", email_msg.subject)
            self.assertIn("video-diff.mp4", email_msg.subject)
            html = BeautifulSoup(email_msg.body)
            html_text = "".join(html.body(text=True)).replace("\n", "")
            if email_number == 0:
                # assert text and timing changes are correct
                self.assertIn('67% of the text', html_text)
                self.assertIn('33% of the timing was changed.', html_text)
            # find the listed text changes to make sure they match
            diff_table = html.findAll('table', attrs={'class': 'diffs'})[0]
            old_version_changes = []
            new_version_changes = []
            for i, node in enumerate(diff_table.findAll('td')):
                if i % 2 == 0:
                    old_version_changes.append(node.text)
                else:
                    new_version_changes.append(node.text)
            self.assertEqual(old_version_changes, [u'2', u'', u''])
            self.assertEqual(new_version_changes, [
                u'2 changed',
                u'new sub',
                u'no sync',
            ])
コード例 #15
0
ファイル: test_users.py プロジェクト: kirimaks/travel_website
 def test_password_setter(self):
     for _ in range(users_number):
         u = User(password=faker.password())
         self.assertTrue(u.password_hash)
コード例 #16
0
 def _create_followers(self, video, num_followers):
     for x in xrange(0, num_followers):
         u = User(username="******" % x,
                  email="*****@*****.**" % x)
         u.save()
         video.followers.add(u)
コード例 #17
0
ファイル: test_users.py プロジェクト: kirimaks/travel_website
 def test_confirmation(self):
     for _ in range(users_number):
         u = User(password=faker.password())
         self.assertFalse(u.confirmed)