Beispiel #1
0
    def test_future(self):
        days = 7


        u_exp5 = User(username='******', password='******', email='.')
        u_exp5.add_paid_time(timedelta(days=5))
        self.session.add(u_exp5)

        u_exp10 = User(username='******', password='******', email='.')
        u_exp10.add_paid_time(timedelta(days=10))
        self.session.add(u_exp10)

        # Same, with last_expiry_notice
        u_exp5l = User(username='******', password='******', email='.')
        u_exp5l.last_expiry_notice = datetime.now() - timedelta(days=1)
        u_exp5l.add_paid_time(timedelta(days=5))
        self.session.add(u_exp5l)

        u_exp5ll = User(username='******', password='******', email='.')
        u_exp5ll.last_expiry_notice = datetime.now() - timedelta(days=30)
        u_exp5ll.add_paid_time(timedelta(days=5))
        self.session.add(u_exp5ll)

        u_exp5 = self.session.query(User).filter_by(username='******').one()
        u_exp10 = self.session.query(User).filter_by(username='******').one()
        u_exp5l = self.session.query(User).filter_by(username='******').one()
        u_exp5ll = self.session.query(User).filter_by(username='******').one()

        users = expire_mail.get_future_expire(days)
        self.assertIn(u_exp5, users)
        self.assertNotIn(u_exp10, users)
        self.assertNotIn(u_exp5l, users)
        self.assertIn(u_exp5ll, users)
Beispiel #2
0
    def setUp(self):
        super().setUp()

        testuser = User(username='******', password='******', email='user@host')
        self.session.add(testuser)
        testuserw = User(username='******', password='******')
        self.session.add(testuserw)
Beispiel #3
0
    def setUp(self):
        self.config = testing.setUp()
        setup_routes(self.config)
        self.session = setup_database()

        self.paiduser = User(username='******', password='******')
        self.paiduser.add_paid_time(datetime.timedelta(days=30))
        self.session.add(self.paiduser)
        self.session.flush()

        self.profile = Profile(uid=self.paiduser.id, name='testprofile')
        self.session.add(self.profile)

        self.freeuser = User(username='******', password='******')
        self.session.add(self.freeuser)

        duser = User(username='******', password='******')
        duser.is_active = False
        duser.add_paid_time(datetime.timedelta(days=30))
        self.session.add(duser)

        self.gw0 = Gateway(name='gw0',
                           token='simple_gateway',
                           isp_name='',
                           isp_url='',
                           country='')
        self.session.add(self.gw0)

        self.gw1 = Gateway(name='gw1',
                           token='disabled_gateway',
                           isp_name='',
                           isp_url='',
                           country='')
        self.gw1.enabled = False
        self.session.add(self.gw1)

        self.gw2 = Gateway(name='gw2',
                           token='ipv4_gateway',
                           isp_name='',
                           isp_url='',
                           country='',
                           ipv4='1.2.3.4')
        self.session.add(self.gw2)

        self.gw3 = Gateway(name='gw3',
                           token='ipv6_gateway',
                           isp_name='',
                           isp_url='',
                           country='',
                           ipv6='1:2:3:4:5:6:7:8')
        self.session.add(self.gw3)
        self.session.flush()

        self.testheaders = {
            'X-Gateway-Token': 'simple_gateway',
            'X-Gateway-Version': 'alpha',
        }
Beispiel #4
0
    def setUp(self):
        super().setUp()

        self.u = User(username='******', password='******')
        DBSession.add(self.u)
        self.session.flush()

        self.pu = User(username='******', password='******')
        self.pu.add_paid_time(datetime.timedelta(days=30))
        DBSession.add(self.pu)
        self.session.flush()
Beispiel #5
0
    def setUp(self):
        self.config = testing.setUp()
        self.session = setup_database()
        self.u = User(username='******', password='******')
        DBSession.add(self.u)
        self.session.flush()

        self.pu = User(username='******', password='******')
        self.pu.add_paid_time(datetime.timedelta(days=30))
        DBSession.add(self.pu)
        self.session.flush()
Beispiel #6
0
    def setUp(self):
        super().setUp()

        self.testuser = User(username='******', password='******')
        self.session.add(self.testuser)
        self.testadmin = User(username='******', password='******')
        self.testadmin.is_admin = True
        self.session.add(self.testadmin)
        self.session.flush()
        self.testcode = GiftCode(datetime.timedelta(days=7))
        self.session.add(self.testcode)
        self.session.flush()
Beispiel #7
0
    def setUp(self):
        settings = {'mako.directories': 'ccvpn:templates/'}
        self.config = testing.setUp(settings=settings)
        setup_routes(self.config)
        self.session = setup_database()

        self.testuser = User(username='******', password='******')
        self.session.add(self.testuser)
        self.testadmin = User(username='******', password='******')
        self.testadmin.is_admin = True
        self.session.add(self.testadmin)
        self.session.flush()
        self.testcode = GiftCode(datetime.timedelta(days=7))
        self.session.add(self.testcode)
        self.session.flush()
Beispiel #8
0
def initialize_db():
    Base.metadata.create_all(DBSession.bind.engine)
    if not DBSession.query(User).filter_by(username='******').count():
        with transaction.manager:
            admin = User(username='******', is_admin=True)
            admin.set_password('admin')
            DBSession.add(admin)
Beispiel #9
0
 def setUp(self):
     super().setUp()
     self.testuser = User(username='******', password='******')
     self.session.add(self.testuser)
     self.testorder = models.Order(user=self.testuser.id, amount=2,
                            method=models.Order.METHOD.BITCOIN,
                            time=timedelta(days=30))
Beispiel #10
0
 def setUp(self):
     self.config = testing.setUp()
     setup_routes(self.config)
     self.session = setup_database()
     self.testuser = User(username='******', password='******')
     self.session.add(self.testuser)
     self.session.flush()
Beispiel #11
0
    def setUp(self):
        settings = {
            'mail.default_sender': 'root@lo',
            'mako.directories': 'ccvpn:templates/'
        }
        self.config = testing.setUp(settings=settings)
        setup_routes(self.config)
        self.config.include('pyramid_mailer.testing')
        self.session = setup_database()

        with transaction.manager:
            testuser = User(username='******',
                            password='******',
                            email='user@host')
            self.session.add(testuser)
            testuserw = User(username='******', password='******')
            self.session.add(testuserw)
Beispiel #12
0
    def test_send(self):
        registry = self.config.registry
        mailer = get_mailer(registry)

        u = User(username='******', email='*****@*****.**',
                 paid_until=datetime.now()+timedelta(days=4))
        expire_mail.send_notice(u, mailer)
        self.assertEqual(len(mailer.outbox), 1)
        self.assertIn('test_user_1', mailer.outbox[0].body)
        self.assertIn('*****@*****.**', mailer.outbox[0].recipients)

        u = User(username='******', email='*****@*****.**',
                 paid_until=datetime.now()+timedelta(days=-4))
        expire_mail.send_notice(u, mailer)
        self.assertEqual(len(mailer.outbox), 2)
        self.assertIn('test_user_2', mailer.outbox[1].body)
        self.assertIn('*****@*****.**', mailer.outbox[1].recipients)
Beispiel #13
0
    def setUp(self):
        super().setUp()

        self.testuser = User(username='******', password='******')
        self.session.add(self.testuser)
        self.session.flush()
        profile = Profile(uid=self.testuser.id, name='testprofile')
        self.session.add(profile)
        self.session.flush()
Beispiel #14
0
    def setUp(self):
        super().setUp()

        testuser = User(username='******', password='******', email='user@host')
        self.session.add(testuser)
        self.session.flush()
        self.token = PasswordResetToken(uid=testuser.id)
        self.session.add(self.token)
        self.session.flush()
Beispiel #15
0
 def setUp(self):
     self.config = testing.setUp()
     self.session = setup_database()
     with transaction.manager:
         self.testuser = User(username='******', password='******')
         self.session.add(self.testuser)
         self.testorder = models.Order(user=self.testuser.id,
                                       amount=2,
                                       method=models.Order.METHOD.BITCOIN,
                                       time=datetime.timedelta(days=30))
Beispiel #16
0
    def setUp(self):
        settings = {'mako.directories': 'ccvpn:templates/'}
        self.config = testing.setUp(settings=settings)
        setup_routes(self.config)
        self.session = setup_database()

        self.testuser = User(username='******', password='******')
        self.session.add(self.testuser)
        self.session.flush()
        profile = Profile(uid=self.testuser.id, name='testprofile')
        self.session.add(profile)
        self.session.flush()
Beispiel #17
0
    def test_paid(self):
        user = User()
        self.assertFalse(user.is_paid)
        self.assertEqual(user.paid_days_left(), 0)

        user.add_paid_time(datetime.timedelta(days=1))
        self.assertTrue(user.is_paid)
        self.assertEqual(user.paid_days_left(), 1)

        user.paid_until = datetime.datetime.fromtimestamp(1)
        user.add_paid_time(datetime.timedelta(days=1))
        self.assertTrue(user.is_paid)
        self.assertEqual(user.paid_days_left(), 1)
Beispiel #18
0
 def test_existing_email(self):
     u = User(username='******', email='user@host', password='******')
     self.session.add(u)
     req = DummyRequest(
         post={
             'username': '******',
             'password': '******',
             'password2': 'newpw',
             'email': 'user@host'
         })
     resp = views.account.signup(req)
     self.assertIsInstance(resp, dict)
     self.assertEqual(req.response.status_code, 400)
Beispiel #19
0
    def test_expired(self):
        u_exp = User(username='******', password='******', email='.',
                   paid_until=datetime.now()-timedelta(days=5))
        u_expl = User(username='******', password='******', email='.',
                   paid_until=datetime.now()-timedelta(days=5),
                   last_expiry_notice=datetime.now()-timedelta(days=12))
        u_expll = User(username='******', password='******', email='.',
                   paid_until=datetime.now()-timedelta(days=5),
                   last_expiry_notice=datetime.now()-timedelta(days=1))
        u_expf = User(username='******', password='******', email='.',
                   paid_until=datetime.now()+timedelta(days=5))
        self.session.add_all([u_exp, u_expl, u_expll, u_expf])

        u_exp = self.session.query(User).filter_by(username='******').one()
        u_expl = self.session.query(User).filter_by(username='******').one()
        u_expll = self.session.query(User).filter_by(username='******').one()
        u_expf = self.session.query(User).filter_by(username='******').one()

        users = expire_mail.get_expired()
        self.assertIn(u_exp, users)
        self.assertIn(u_expl, users)
        self.assertNotIn(u_expll, users)
        self.assertNotIn(u_expf, users)
Beispiel #20
0
def signup(request):
    ## TODO: seriously needs refactoring

    _ = request.translate
    if request.method != 'POST':
        return {}
    errors = []

    try:
        username = request.POST.get('username')
        password = request.POST.get('password')
        password2 = request.POST.get('password2')
        email = request.POST.get('email')

        if not User.validate_username(username):
            errors.append(_('Invalid username.'))
        if not User.validate_password(password):
            errors.append(_('Invalid password.'))
        if email and not User.validate_email(email):
            errors.append(_('Invalid email address.'))
        if password != password2:
            errors.append(_('Both passwords do not match.'))

        assert not errors

        used = User.is_used(username, email)
        if used[0] > 0:
            errors.append(_('Username already registered.'))
        if used[1] > 0 and email:
            errors.append(_('E-mail address already registered.'))

        assert not errors

        with transaction.manager:
            u = User(username=username, email=email, password=password)
            if request.referrer:
                u.referrer_id = request.referrer.id
            DBSession.add(u)
            DBSession.flush()
            dp = Profile(uid=u.id, name='')
            DBSession.add(dp)
            request.session['uid'] = u.id
        return HTTPSeeOther(location=request.route_url('account'))
    except AssertionError:
        for error in errors:
            request.messages.error(error)
        fields = ('username', 'password', 'password2', 'email')
        request.response.status_code = HTTPBadRequest.code
        return {k: request.POST[k] for k in fields}
Beispiel #21
0
    def setUp(self):
        settings = {
            'mail.default_sender': 'root@lo',
            'mako.directories': 'ccvpn:templates/'
        }
        self.config = testing.setUp(settings=settings)
        setup_routes(self.config)
        self.config.include('pyramid_mailer.testing')
        self.session = setup_database()

        testuser = User(username='******', password='******', email='user@host')
        self.session.add(testuser)
        self.session.flush()
        self.token = PasswordResetToken(uid=testuser.id)
        self.session.add(self.token)
        self.session.flush()
Beispiel #22
0
    def test_view_not_owned(self):
        otheruser = User(username='******', password='******')
        self.session.add(otheruser)
        self.session.flush()

        testorder = Order(user=otheruser.id,
                          amount=1,
                          method=Order.METHOD.PAYPAL,
                          time=datetime.timedelta(days=30))
        self.session.add(testorder)
        self.session.flush()

        req = DummyRequest()
        req.session['uid'] = self.testuser.id
        req.matchdict['hexid'] = '%x' % testorder.id
        resp = views.order.order_view(req)
        self.assertIsInstance(resp, httpexceptions.HTTPUnauthorized)
Beispiel #23
0
    def test_valid_referral(self):
        with transaction.manager:
            _referrer = User(username='******', password='******')
            self.session.add(_referrer)

        referrer = self.session.query(User).filter_by(username='******').first()
        self.assertFalse(referrer.is_paid)

        req = DummyRequest(post={
            'username': '******',
            'password': '******',
            'password2': 'newpw',
            'email': 'email@host'
        },
                           params={
                               'ref': str(referrer.id),
                           })
        resp = views.account.signup(req)

        newuser = self.session.query(User).filter_by(username='******') \
                              .first()
        self.assertIsInstance(resp, httpexceptions.HTTPSeeOther)
        self.assertTrue(resp.location.endswith('/account/'))
        self.assertEqual(newuser.referrer_id, referrer.id)

        self.assertFalse(referrer.is_paid)

        testorder = Order(user=newuser,
                          amount=1,
                          method=Order.METHOD.BITCOIN,
                          time=datetime.timedelta(days=30))
        self.session.add(testorder)
        self.session.add(referrer)
        self.session.flush()
        testorder.close(force=True)
        self.session.flush()

        self.session.refresh(referrer)
        self.assertTrue(referrer.is_paid)
Beispiel #24
0
 def setUp(self):
     self.config = testing.setUp()
     self.session = setup_database()
     u = User(username='******', email='test@host', password='******')
     DBSession.add(u)
     self.session.flush()
Beispiel #25
0
 def test_str(self):
     user = User(username='******')
     self.assertEqual(user.username, str(user))
Beispiel #26
0
 def test_password(self):
     user = User()
     self.assertFalse(user.check_password(''))
     user.set_password('pw')
     self.assertTrue(user.check_password('pw'))
     self.assertFalse(user.check_password('!pw'))
Beispiel #27
0
    def test_construct(self):
        user = User(username='******', password='******')
        self.assertEqual(user.username, 'test')

        self.assertTrue(user.check_password('pw'))
        self.assertFalse(user.check_password('!pw'))
Beispiel #28
0
    def setUp(self):
        super().setUp()

        self.testuser = User(username='******', password='******')
        self.session.add(self.testuser)
        self.session.flush()
Beispiel #29
0
    def setUp(self):
        super().setUp()

        u = User(username='******', email='test@host', password='******')
        DBSession.add(u)
        self.session.flush()