Exemple #1
0
    def test_markdown_extensions(self):
        pages = FlatPages(Flask(__name__))

        hello = pages.get('headerid')
        self.assertEqual(
            hello.html,
            u'<h1>Page Header</h1>\n<h2>Paragraph Header</h2>\n<p>Text</p>')

        pages.app.config['FLATPAGES_MARKDOWN_EXTENSIONS'] = []
        pages.reload()
        pages._file_cache = {}

        hello = pages.get('headerid')
        self.assertEqual(
            hello.html,
            u'<h1>Page Header</h1>\n<h2>Paragraph Header</h2>\n<p>Text</p>')

        pages.app.config['FLATPAGES_MARKDOWN_EXTENSIONS'] = [
            'codehilite', 'headerid'
        ]
        pages.reload()
        pages._file_cache = {}

        hello = pages.get('headerid')
        self.assertEqual(
            hello.html, u'<h1 id="page-header">Page Header</h1>\n'
            u'<h2 id="paragraph-header">Paragraph Header</h2>\n'
            u'<p>Text</p>')
Exemple #2
0
 def test_iter(self):
     pages = FlatPages(Flask(__name__))
     self.assertEqual(
         set(page.path for page in pages),
         set([
             'codehilite', 'extra', 'foo', 'foo/bar', 'foo/lorem/ipsum',
             'headerid', 'hello', 'toc'
         ]))
Exemple #3
0
def create_app(**options):
    """
    Initialize Flask application and FlatPages extension.
    """
    app = Flask(__name__)
    app.config.update(options)

    pages = FlatPages(app)
    return (app, pages)
Exemple #4
0
 def test_extension_sequence(self, extension=None):
     app = Flask(__name__)
     app.config['FLATPAGES_EXTENSION'] = extension or ['.html', '.txt']
     pages = FlatPages(app)
     self.assertEqual(
         set(page.path for page in pages),
         set([
             'codehilite', 'extra', 'foo', 'foo/42/not_a_page', 'foo/bar',
             'foo/lorem/ipsum', 'headerid', 'hello', 'not_a_page', 'toc'
         ]))
Exemple #5
0
 def test_yaml_meta(self):
     pages = FlatPages(Flask(__name__))
     foo = pages.get('foo')
     self.assertEqual(
         foo.meta, {
             'title': 'Foo > bar',
             'created': datetime.date(2010, 12, 11),
             'versions': [3.14, 42]
         })
     self.assertEqual(foo['title'], 'Foo > bar')
     self.assertEqual(foo['created'], datetime.date(2010, 12, 11))
     self.assertEqual(foo['versions'], [3.14, 42])
     self.assertRaises(KeyError, lambda: foo['nonexistent'])
Exemple #6
0
def temp_pages(app=None, name=None):
    """This context manager gives a FlatPages object configured
    in a temporary directory with a copy of the test pages.

    Using a temporary copy allows us to safely write and remove stuff without
    worrying about undoing our changes.
    """
    with temp_directory() as temp:
        source = os.path.join(os.path.dirname(__file__), 'pages')
        # Remove the destination dir as copytree wants it not to exist.
        # Doing so kind of defeats the purpose of tempfile as it introduces
        # a race condition, but should be good enough for our purpose.
        os.rmdir(temp)
        shutil.copytree(source, temp)
        app = app or Flask(__name__)
        if name is None:
            config_root = 'FLATPAGES_ROOT'
        else:
            config_root = 'FLATPAGES_%s_ROOT' % str(name).upper()
        app.config[config_root] = temp
        yield FlatPages(app, name)
Exemple #7
0
def setup(app):
    db.init_app(app)
    mail.init_app(app)
    #login_manager.init_app(app)

    admin = Admin(app)
    bootstrap = Bootstrap(app)

    app.register_plugin("website.security")
    setup_filters_and_processors(app)

    app.register_plugin("website.views")
    #app.register_plugin("website.cfp")
    app.register_plugin("website.registration")
    app.register_plugin("website.crm")
    app.register_plugin("website.sdc")  # Students demo cup

    # Add some extensions
    whoosh = Whoosh(app)

    pages = FlatPages(app)
    app.extensions['pages'] = pages

    setup_freezer(app)
    markdown_manager = Markdown(app)
    asset_manager = AssetManager(app)
    app.extensions['asset_manager'] = asset_manager

    # Setup custome babel config (see below)
    setup_babel(app)

    # Setup hierarchical Jinja2 template loader
    # TODO: should be generic
    setup_template_loader(app)

    create_db(app)
    load_tracks(app)

    if not app.config.get('TESTING'):
        pass
Exemple #8
0
    def test_other_html_renderer(self):
        def body_renderer(body):
            return body.upper()

        def page_renderer(body, pages, page):
            return page.body.upper()

        def pages_renderer(body, pages):
            return pages.get('hello').body.upper()

        renderers = filter(None,
                           (operator.methodcaller('upper'),
                            'string.upper' if not compat.IS_PY3 else None,
                            body_renderer, page_renderer, pages_renderer))

        for renderer in (renderers):
            pages = FlatPages(Flask(__name__))
            pages.app.config['FLATPAGES_HTML_RENDERER'] = renderer
            hello = pages.get('hello')
            self.assertEqual(hello.body, u'Hello, *世界*!\n')
            # Upper-case, markdown not interpreted
            self.assertEqual(hello.html, u'HELLO, *世界*!\n')
Exemple #9
0
from solr import SolrConnection

from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
from flask.ext.flatpages import FlatPages
from flask.ext.mail import Mail

from offenesparlament import default_settings

app = Flask(__name__)
app.config.from_object(default_settings)
app.config.from_envvar('PARLAMENT_SETTINGS', silent=True)

db = SQLAlchemy(app)
pages = FlatPages(app)
mail = Mail(app)


def solr():
    return SolrConnection(app.config['SOLR_URL'],
                          http_user=app.config.get('SOLR_USER'),
                          http_pass=app.config.get('SOLR_PASSWORD'))


def etl_engine():
    from sqlaload import connect
    return connect(app.config['ETL_URL'])


def archive_path(*a):
Exemple #10
0
 def test_other_extension(self):
     app = Flask(__name__)
     app.config['FLATPAGES_EXTENSION'] = '.txt'
     pages = FlatPages(app)
     self.assertEqual(set(page.path for page in pages),
                      set(['not_a_page', 'foo/42/not_a_page']))
Exemple #11
0
 def test_unicode(self):
     pages = FlatPages(Flask(__name__))
     self._unicode(pages)
Exemple #12
0
 def test_other_encoding(self):
     app = Flask(__name__)
     app.config['FLATPAGES_ENCODING'] = 'shift_jis'
     app.config['FLATPAGES_ROOT'] = 'pages_shift_jis'
     pages = FlatPages(app)
     self._unicode(pages)
from flask import Flask
from flask.ext.flatpages import FlatPages
from flask.ext.frozen import Freezer
from flask.ext.bootstrap import Bootstrap
from config import config

pages = FlatPages()
freezer = Freezer()
bootstrap = Bootstrap()


def create_app(config_name):
    app = Flask(__name__)
    app.config.from_object(config[config_name])

    freezer.init_app(app)
    pages.init_app(app)
    bootstrap.init_app(app)

    #register blueprints:
    from .main import main as main_blueprint
    app.register_blueprint(main_blueprint)

    return app
Exemple #14
0
 def __init__(self):
     self.flat_pages = FlatPages()
     self.root_category = Category(None, '<root>')
Exemple #15
0
 def test_consistency(self):
     pages = FlatPages(Flask(__name__))
     for page in pages:
         assert pages.get(page.path) is page
Exemple #16
0
 def test_get_or_404(self):
     pages = FlatPages(Flask(__name__))
     self.assertEqual(pages.get_or_404('foo/bar').path, 'foo/bar')
     self.assertRaises(NotFound, pages.get_or_404, 'nonexistent')
Exemple #17
0
 def test_get(self):
     pages = FlatPages(Flask(__name__))
     self.assertEqual(pages.get('foo/bar').path, 'foo/bar')
     self.assertEqual(pages.get('nonexistent'), None)
     self.assertEqual(pages.get('nonexistent', 42), 42)
Exemple #18
0
 def test_markdown(self):
     pages = FlatPages(Flask(__name__))
     foo = pages.get('foo')
     self.assertEqual(foo.body, 'Foo *bar*\n')
     self.assertEqual(foo.html, '<p>Foo <em>bar</em></p>')
Exemple #19
0
    app.config.from_pyfile(os.path.join(os.getcwd(), 'config.py'))
except IOError:
    print 'Can not find config.py'
    sys.exit()

# To avoid full paths in config.py
app.config['FLATPAGES_ROOT'] = os.path.join(os.getcwd(),
                                            app.config.get('POSTS_FOLDER'))
app.config['FREEZER_DESTINATION'] = os.path.join(
    os.getcwd(), app.config.get('BUILD_FOLDER'))
app.config['FLATPAGES_EXTENSION'] = app.config.get('POSTS_EXTENSION')

app.config['INCLUDE_JS'] = 'combined.min.js' in os.listdir(app.static_folder)
app.config['INCLUDE_CSS'] = 'combined.min.css' in os.listdir(app.static_folder)

posts = FlatPages(app)
freezer = Freezer(app)

# Allow config settings (even new user created ones) to be used in templates
for key in app.config:
    app.jinja_env.globals[key] = app.config[key]


def truncate_post_html(post_html):
    return BeautifulSoup(post_html[:255]).prettify()


app.jinja_env.globals['truncate_post_html'] = truncate_post_html

app.jinja_loader = ChoiceLoader([
    FileSystemLoader(os.path.join(os.getcwd(), 'templates/')), app.jinja_loader