jax 1.1.1 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +4 -0
- data/.rvmrc +2 -3
- data/.travis.yml +8 -22
- data/README.md +2 -2
- data/Rakefile +128 -96
- data/app/assets/javascripts/jax/controller-list.js.coffee +22 -0
- data/app/assets/javascripts/jax/dom-helpers.js.coffee +17 -0
- data/app/assets/javascripts/jax/jasmine_runner.js +177 -0
- data/app/assets/javascripts/jax/runtime.js +6 -0
- data/app/assets/javascripts/jax/shader_editor.js.coffee +33 -0
- data/app/assets/stylesheets/jax/controller-list.css +5 -0
- data/app/assets/stylesheets/jax/jasmine.css +16 -0
- data/app/assets/stylesheets/jax/nav.css +41 -0
- data/app/assets/stylesheets/jax/runtime.css +47 -0
- data/app/assets/stylesheets/jax/shader_editor.css +3 -0
- data/app/assets/stylesheets/jax/suite.css +82 -0
- data/app/controllers/jax/suite_controller.rb +48 -0
- data/app/views/jax/suite/jasmine.html.erb +38 -0
- data/app/views/jax/suite/run_webgl.html.erb +49 -0
- data/app/views/jax/suite/shader_editor.html.erb +24 -0
- data/app/views/layouts/jax.html.erb +40 -0
- data/bin/jax +8 -4
- data/config/routes.rb +2 -0
- data/config.ru +5 -0
- data/features/rails/resources.feature +45 -0
- data/features/rails/shaders.feature +13 -0
- data/features/rails/specs.feature +24 -0
- data/features/runtime.feature +15 -0
- data/features/step_definitions/environment_steps.rb +15 -0
- data/features/step_definitions/response_steps.rb +13 -0
- data/features/step_definitions/runtime.rb +11 -0
- data/features/step_definitions/web_steps.rb +223 -0
- data/features/support/env.rb +75 -0
- data/features/support/paths.rb +30 -0
- data/features/support/rails_environment.rb +3 -0
- data/features/support/selectors.rb +39 -0
- data/features/support/setup.rb +17 -0
- data/jax.gemspec +22 -16
- data/lib/assets/javascripts/jax/anim_frame.js +64 -0
- data/lib/assets/javascripts/jax/application.js +16 -0
- data/lib/assets/javascripts/jax/builtin/all.js +21 -0
- data/lib/assets/javascripts/jax/builtin/meshes/cube.js +83 -0
- data/lib/assets/javascripts/jax/builtin/meshes/plane.js +67 -0
- data/lib/assets/javascripts/jax/builtin/meshes/quad.js +89 -0
- data/lib/assets/javascripts/jax/builtin/meshes/sphere.js +65 -0
- data/lib/assets/javascripts/jax/builtin/meshes/teapot.js +48 -0
- data/lib/assets/javascripts/jax/builtin/meshes/torus.js +64 -0
- data/lib/assets/javascripts/jax/compatibility.js +312 -0
- data/lib/assets/javascripts/jax/context.js +741 -0
- data/lib/assets/javascripts/jax/core/base.js +69 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/mat3.js +20 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/mat4.js +10 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/quat4.js +148 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/vec2.js +25 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/vec3.js +86 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/vec4.js +28 -0
- data/lib/assets/javascripts/jax/core/helper.js +44 -0
- data/lib/assets/javascripts/jax/core/math.js +61 -0
- data/lib/assets/javascripts/jax/core/matrix_stack.js +310 -0
- data/lib/assets/javascripts/jax/core/util.js +271 -0
- data/lib/assets/javascripts/jax/core.js +43 -0
- data/lib/assets/javascripts/jax/events.js +304 -0
- data/lib/assets/javascripts/jax/geometry/line.js +185 -0
- data/lib/assets/javascripts/jax/geometry/plane.js +371 -0
- data/lib/assets/javascripts/jax/geometry/triangle/inliner.rb +94 -0
- data/lib/assets/javascripts/jax/geometry/triangle/slow_tri_tri_intersect.js +20 -0
- data/lib/assets/javascripts/jax/geometry/triangle/tri_tri_intersect.js +281 -0
- data/lib/assets/javascripts/jax/geometry/triangle/tri_tri_intersect_optimized.js +564 -0
- data/lib/assets/javascripts/jax/geometry/triangle.js +311 -0
- data/lib/assets/javascripts/jax/geometry.js +14 -0
- data/lib/assets/javascripts/jax/mvc/controller.js +188 -0
- data/lib/assets/javascripts/jax/mvc/model.js +302 -0
- data/lib/assets/javascripts/jax/mvc/route_set.js +148 -0
- data/lib/assets/javascripts/jax/mvc/view.js +43 -0
- data/lib/assets/javascripts/jax/mvc/view_manager.js +65 -0
- data/lib/assets/javascripts/jax/noise.js +251 -0
- data/lib/assets/javascripts/jax/prototype/class.js +81 -0
- data/lib/assets/javascripts/jax/prototype/core.js +112 -0
- data/lib/assets/javascripts/jax/prototype/extensions.js +142 -0
- data/lib/assets/javascripts/jax/vendor/ejs.js +1 -0
- data/lib/assets/javascripts/jax/vendor/glMatrix.js +7 -0
- data/lib/assets/javascripts/jax/webgl/camera.js +697 -0
- data/lib/assets/javascripts/jax/webgl/cleanup.js +1 -0
- data/lib/assets/javascripts/jax/webgl/core/buffer.js +292 -0
- data/lib/assets/javascripts/jax/webgl/core/data_region.js +184 -0
- data/lib/assets/javascripts/jax/webgl/core/data_segment.js +255 -0
- data/lib/assets/javascripts/jax/webgl/core/events.js +99 -0
- data/lib/assets/javascripts/jax/webgl/core/framebuffer.js +316 -0
- data/lib/assets/javascripts/jax/webgl/core.js +6 -0
- data/lib/assets/javascripts/jax/webgl/material.js +381 -0
- data/lib/assets/javascripts/jax/webgl/mesh/normals.js +37 -0
- data/lib/assets/javascripts/jax/webgl/mesh/support.js +104 -0
- data/lib/assets/javascripts/jax/webgl/mesh/tangent_space.js +111 -0
- data/lib/assets/javascripts/jax/webgl/mesh.js +440 -0
- data/lib/assets/javascripts/jax/webgl/scene/frustum.js +422 -0
- data/lib/assets/javascripts/jax/webgl/scene/light_manager.js +141 -0
- data/lib/assets/javascripts/jax/webgl/scene/light_source.js +300 -0
- data/lib/assets/javascripts/jax/webgl/scene.js +16 -0
- data/lib/assets/javascripts/jax/webgl/shader/delegator/attribute.js +53 -0
- data/lib/assets/javascripts/jax/webgl/shader/delegator/uniform.js +71 -0
- data/lib/assets/javascripts/jax/webgl/shader/delegator.js +13 -0
- data/lib/assets/javascripts/jax/webgl/shader/manifest.js +70 -0
- data/lib/assets/javascripts/jax/webgl/shader/program.js +138 -0
- data/lib/assets/javascripts/jax/webgl/shader.js +299 -0
- data/lib/assets/javascripts/jax/webgl/shader_chain.js +267 -0
- data/lib/assets/javascripts/jax/webgl/texture.js +506 -0
- data/lib/assets/javascripts/jax/webgl/world.js +279 -0
- data/lib/assets/javascripts/jax/webgl.js +109 -0
- data/lib/assets/javascripts/jax.js +136 -0
- data/{builtin/app/shaders/basic/common.ejs → lib/assets/javascripts/shaders/basic/common.glsl} +0 -0
- data/{builtin/app/shaders/basic/fragment.ejs → lib/assets/javascripts/shaders/basic/fragment.glsl} +0 -0
- data/{builtin/app/shaders/basic/vertex.ejs → lib/assets/javascripts/shaders/basic/vertex.glsl} +1 -1
- data/{builtin/app/shaders/depthmap/common.ejs → lib/assets/javascripts/shaders/depthmap/common.glsl} +0 -0
- data/{builtin/app/shaders/depthmap/fragment.ejs → lib/assets/javascripts/shaders/depthmap/fragment.glsl} +1 -1
- data/{builtin/app → lib/assets/javascripts}/shaders/depthmap/material.js +0 -0
- data/{builtin/app/shaders/depthmap/vertex.ejs → lib/assets/javascripts/shaders/depthmap/vertex.glsl} +0 -0
- data/{builtin/app/shaders/fog/common.ejs → lib/assets/javascripts/shaders/fog/common.glsl} +0 -0
- data/{builtin/app/shaders/fog/fragment.ejs → lib/assets/javascripts/shaders/fog/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/fog/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/fog/material.js +6 -8
- data/{builtin/app/shaders/fog/vertex.ejs → lib/assets/javascripts/shaders/fog/vertex.glsl} +0 -0
- data/{builtin/app/shaders/functions/depth_map.ejs → lib/assets/javascripts/shaders/functions/depth_map.glsl} +0 -0
- data/{builtin/app/shaders/functions/lights.ejs → lib/assets/javascripts/shaders/functions/lights.glsl} +0 -0
- data/{builtin/app/shaders/functions/noise.ejs → lib/assets/javascripts/shaders/functions/noise.glsl} +0 -0
- data/lib/assets/javascripts/shaders/lighting/common.glsl +5 -0
- data/{builtin/app/shaders/lighting/fragment.ejs → lib/assets/javascripts/shaders/lighting/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/lighting/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/lighting/material.js +2 -4
- data/{builtin/app/shaders/lighting/vertex.ejs → lib/assets/javascripts/shaders/lighting/vertex.glsl} +0 -0
- data/{builtin/app/shaders/normal_map/common.ejs → lib/assets/javascripts/shaders/normal_map/common.glsl} +1 -1
- data/{builtin/app/shaders/normal_map/fragment.ejs → lib/assets/javascripts/shaders/normal_map/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/normal_map/manifest.yml +0 -0
- data/lib/assets/javascripts/shaders/normal_map/material.js +11 -0
- data/{builtin/app/shaders/normal_map/vertex.ejs → lib/assets/javascripts/shaders/normal_map/vertex.glsl} +0 -0
- data/{builtin/app/shaders/paraboloid/common.ejs → lib/assets/javascripts/shaders/paraboloid/common.glsl} +0 -0
- data/{builtin/app/shaders/paraboloid/fragment.ejs → lib/assets/javascripts/shaders/paraboloid/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/paraboloid/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/paraboloid/material.js +2 -4
- data/{builtin/app/shaders/paraboloid/vertex.ejs → lib/assets/javascripts/shaders/paraboloid/vertex.glsl} +0 -0
- data/{builtin/app/shaders/picking/common.ejs → lib/assets/javascripts/shaders/picking/common.glsl} +0 -0
- data/{builtin/app/shaders/picking/fragment.ejs → lib/assets/javascripts/shaders/picking/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/picking/material.js +2 -4
- data/{builtin/app/shaders/picking/vertex.ejs → lib/assets/javascripts/shaders/picking/vertex.glsl} +0 -0
- data/{builtin/app/shaders/shadow_map/common.ejs → lib/assets/javascripts/shaders/shadow_map/common.glsl} +2 -1
- data/{builtin/app/shaders/shadow_map/fragment.ejs → lib/assets/javascripts/shaders/shadow_map/fragment.glsl} +1 -1
- data/{builtin/app → lib/assets/javascripts}/shaders/shadow_map/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/shadow_map/material.js +4 -6
- data/{builtin/app/shaders/shadow_map/vertex.ejs → lib/assets/javascripts/shaders/shadow_map/vertex.glsl} +0 -0
- data/{builtin/app/shaders/texture/common.ejs → lib/assets/javascripts/shaders/texture/common.glsl} +0 -0
- data/{builtin/app/shaders/texture/fragment.ejs → lib/assets/javascripts/shaders/texture/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/texture/manifest.yml +0 -0
- data/lib/assets/javascripts/shaders/texture/material.js +17 -0
- data/{builtin/app/shaders/texture/vertex.ejs → lib/assets/javascripts/shaders/texture/vertex.glsl} +0 -0
- data/lib/generators/jax/all.rb +16 -0
- data/lib/generators/jax/application/application_generator.rb +48 -0
- data/lib/generators/jax/base/actions.rb +52 -0
- data/lib/generators/jax/base/coffee_generator.rb +30 -0
- data/lib/generators/jax/base/named_base.rb +17 -0
- data/lib/generators/jax/base/plugin_base.rb +108 -0
- data/lib/generators/jax/base/plugin_credentials.rb +99 -0
- data/lib/generators/jax/base/plugin_manifest.rb +75 -0
- data/lib/generators/jax/base/rails_base.rb +30 -0
- data/lib/generators/jax/base/source_root.rb +5 -0
- data/lib/generators/jax/controller/controller_generator.rb +37 -0
- data/lib/generators/jax/helper/helper_generator.rb +30 -0
- data/lib/generators/jax/install/install_generator.rb +27 -0
- data/lib/generators/jax/jax_generator.rb +13 -0
- data/lib/generators/jax/light/light_generator.rb +23 -0
- data/lib/{jax/generators → generators/jax}/material/USAGE +4 -8
- data/lib/generators/jax/material/material_generator.rb +112 -0
- data/lib/generators/jax/model/model_generator.rb +24 -0
- data/lib/generators/jax/plugin/plugin_generator.rb +72 -0
- data/lib/generators/jax/scaffold/scaffold_generator.rb +35 -0
- data/lib/generators/jax/shader/shader_generator.rb +38 -0
- data/lib/jax/commands/plugin_manager.rb +240 -0
- data/lib/jax/commands.rb +69 -0
- data/lib/jax/configuration.rb +64 -0
- data/lib/jax/directive_processor.rb +53 -0
- data/lib/jax/engine.rb +38 -54
- data/lib/jax/helper_methods.rb +3 -0
- data/lib/jax/rails/application.rb +34 -0
- data/lib/jax/resource_file.rb +29 -0
- data/lib/jax/script_loader.rb +68 -0
- data/lib/jax/server.rb +87 -0
- data/lib/jax/shader.rb +70 -172
- data/lib/jax/testing/rails_environment.rb +94 -0
- data/lib/jax/util/tar.rb +75 -0
- data/lib/jax/util.rb +3 -0
- data/lib/jax/version.rb +7 -8
- data/lib/jax.rb +23 -41
- data/spec/bin/jax_spec.rb +149 -0
- data/{lib/jax/generators/app/templates/app/models/.empty_directory → spec/fixtures/public/favicon.ico} +0 -0
- data/spec/fixtures/public/textures/brickwall.jpg +0 -0
- data/spec/fixtures/public/textures/jacks.jpg +0 -0
- data/spec/fixtures/public/textures/normal_map.jpg +0 -0
- data/spec/fixtures/public/textures/rock.png +0 -0
- data/spec/fixtures/public/textures/rock_normal.png +0 -0
- data/spec/fixtures/public/textures/rss.png +0 -0
- data/spec/generators/jax/application_generator_spec.rb +18 -0
- data/spec/generators/jax/controller_generator_spec.rb +102 -0
- data/spec/generators/jax/helper_generator_spec.rb +55 -0
- data/spec/generators/jax/install_generator_spec.rb +30 -0
- data/spec/generators/jax/jax_generator_spec.rb +21 -0
- data/spec/generators/jax/light_generator_spec.rb +27 -0
- data/spec/generators/jax/material_generator_spec.rb +62 -0
- data/spec/generators/jax/model_generator_spec.rb +72 -0
- data/spec/generators/jax/plugin_generator_spec.rb +143 -0
- data/spec/generators/jax/scaffold_generator_spec.rb +35 -0
- data/spec/generators/jax/shader_generator_spec.rb +37 -0
- data/spec/javascripts/helpers/jasmine_webgl_helper.js +13 -0
- data/{lib/jax/generators/app/templates/spec/javascripts/support/spec_helpers → spec/javascripts/helpers}/jax_spec_environment_helper.js +7 -2
- data/{lib/jax/generators/app/templates/spec/javascripts/support/spec_helpers → spec/javascripts/helpers}/jax_spec_helper.js +0 -0
- data/spec/javascripts/jax/builtin/meshes/cube_spec.js +10 -0
- data/spec/javascripts/jax/builtin/meshes/plane_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/quad_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/sphere_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/teapot_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/torus_spec.js +8 -0
- data/spec/javascripts/jax/compatibility_spec.js +46 -0
- data/spec/javascripts/jax/context_events_spec.js +212 -0
- data/spec/javascripts/jax/context_spec.js +305 -0
- data/spec/javascripts/jax/core/data_region_spec.js +118 -0
- data/spec/javascripts/jax/core/data_segment_spec.js +96 -0
- data/spec/javascripts/jax/core/delegation_spec.js +48 -0
- data/spec/javascripts/jax/core/events_spec.js +17 -0
- data/spec/javascripts/jax/core/glMatrix_extensions_spec.js +8 -0
- data/spec/javascripts/jax/core/helper_spec.js +61 -0
- data/spec/javascripts/jax/core/matrix_stack_spec.js +28 -0
- data/spec/javascripts/jax/core/utils_spec.js +275 -0
- data/spec/javascripts/jax/geometry/line_spec.js +20 -0
- data/spec/javascripts/jax/geometry/plane_spec.js +181 -0
- data/spec/javascripts/jax/geometry/triangle_spec.js +105 -0
- data/spec/javascripts/jax/mvc/controller_spec.js +156 -0
- data/spec/javascripts/jax/mvc/model_spec.js +93 -0
- data/spec/javascripts/jax/mvc/route_set_spec.js +49 -0
- data/spec/javascripts/jax/mvc/view_manager_spec.js +17 -0
- data/spec/javascripts/jax/noise_spec.js +50 -0
- data/spec/javascripts/jax/optimizations/material_limitations_spec.js +85 -0
- data/spec/javascripts/jax/optimizations/shaders/basic_spec.js +65 -0
- data/spec/javascripts/jax/prototype/extensions_spec.js +34 -0
- data/spec/javascripts/jax/webgl/camera_spec.js +237 -0
- data/spec/javascripts/jax/webgl/core/events_spec.js +47 -0
- data/spec/javascripts/jax/webgl/framebuffer_spec.js +44 -0
- data/spec/javascripts/jax/webgl/lighting_spec.js +108 -0
- data/spec/javascripts/jax/webgl/material_spec.js +117 -0
- data/spec/javascripts/jax/webgl/mesh_spec.js +228 -0
- data/spec/javascripts/jax/webgl/shader/manifest_spec.js +57 -0
- data/spec/javascripts/jax/webgl/shader_chain_spec.js +211 -0
- data/spec/javascripts/jax/webgl/shader_spec.js +276 -0
- data/spec/javascripts/jax/webgl/tangent_space_spec.js +142 -0
- data/spec/javascripts/jax/webgl/texture_spec.js +159 -0
- data/spec/javascripts/jax/webgl_spec.js +5 -0
- data/spec/javascripts/jax/world_spec.js +175 -0
- data/spec/javascripts/jax_spec.js +14 -0
- data/spec/javascripts/node/mocks/webgl.js +159 -0
- data/spec/javascripts/node_helper.js +51 -0
- data/spec/javascripts/shaders/core_materials_spec.js +38 -0
- data/spec/javascripts/shaders/fog_spec.js +15 -0
- data/spec/javascripts/shaders/lighting_spec.js +15 -0
- data/spec/javascripts/shaders/normal_map_spec.js +15 -0
- data/spec/javascripts/shaders/paraboloid_spec.js +33 -0
- data/spec/javascripts/shaders/preprocessor_spec.js +45 -0
- data/spec/javascripts/shaders/shadow_map_spec.js +15 -0
- data/spec/javascripts/shaders/texture_spec.js +37 -0
- data/spec/javascripts/suite/controller_select_spec.js.coffee +24 -0
- data/spec/lib/jax/commands/plugin_manager/credentials_spec.rb +56 -0
- data/spec/lib/jax/commands/plugin_manager/push_spec.rb +62 -0
- data/spec/lib/jax/commands/plugin_manager_spec.rb +204 -0
- data/spec/lib/jax/rails/application_spec.rb +23 -0
- data/spec/lib/jax/shader_spec.rb +67 -0
- data/spec/lib/jax/util/tar_spec.rb +26 -0
- data/spec/{test_helper.rb → spec_helper.rb} +37 -28
- data/spec/support/test_model_generator.rb +14 -0
- data/templates/app/Gemfile.tt +17 -0
- data/templates/app/Rakefile +4 -0
- data/templates/app/config/application.rb +16 -0
- data/{lib/jax/generators/app/templates → templates/app}/config/boot.rb +0 -0
- data/templates/app/config/environment.rb +5 -0
- data/templates/app/config/environments/production.rb +4 -0
- data/templates/app/config.ru +6 -0
- data/{lib/jax/generators/app/templates/app/resources → templates/app/public}/.empty_directory +0 -0
- data/templates/app/script/jax +8 -0
- data/{lib/jax/generators/app/templates/app/views → templates/app/spec}/.empty_directory +0 -0
- data/templates/application_controller.js.coffee.erb +3 -0
- data/templates/application_controller.js.erb +6 -0
- data/templates/application_helper.js.coffee.erb +3 -0
- data/templates/application_helper.js.erb +3 -0
- data/templates/controller.js.coffee.erb +9 -0
- data/templates/controller.js.erb +15 -0
- data/templates/controller_spec.js.coffee.erb +9 -0
- data/templates/controller_spec.js.erb +12 -0
- data/templates/helper.js.coffee.erb +2 -0
- data/templates/helper.js.erb +3 -0
- data/templates/helper_spec.js.coffee.erb +8 -0
- data/templates/helper_spec.js.erb +12 -0
- data/{lib/jax/generators/light_source/templates/light.yml.tt → templates/light_source.resource.erb} +3 -3
- data/{lib/jax/generators/material/templates/material.yml.tt → templates/material.resource.erb} +0 -9
- data/templates/model.js.coffee.erb +3 -0
- data/templates/model.js.erb +5 -0
- data/templates/model_defaults.resource.erb +5 -0
- data/templates/model_spec.js.coffee.erb +16 -0
- data/templates/model_spec.js.erb +18 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/controllers/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/helpers/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/models/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/resources/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/views/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates → templates}/new_plugin/init.rb +0 -0
- data/{lib/jax/generators/plugin/templates → templates}/new_plugin/install.rb +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/public → templates/new_plugin/spec}/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates → templates}/new_plugin/uninstall.rb +0 -0
- data/{lib/jax/generators/shader/templates/common.ejs.tt → templates/shader_common.glsl.erb} +0 -0
- data/{lib/jax/generators/shader/templates/fragment.ejs.tt → templates/shader_fragment.glsl.erb} +0 -0
- data/{lib/jax/generators/shader/templates/manifest.yml.tt → templates/shader_manifest.yml.erb} +0 -0
- data/templates/shader_material.js.coffee.erb +22 -0
- data/{lib/jax/generators/shader/templates/material.js.tt → templates/shader_material.js.erb} +0 -0
- data/templates/shader_spec.js.coffee.erb +16 -0
- data/{lib/jax/generators/shader/templates/spec.js.tt → templates/shader_spec.js.erb} +1 -1
- data/{lib/jax/generators/shader/templates/vertex.ejs.tt → templates/shader_vertex.glsl.erb} +0 -0
- data/templates/view.js.coffee.erb +3 -0
- data/{lib/jax/generators/controller/templates/view.js.tt → templates/view.js.erb} +1 -1
- data/vendor/assets/javascripts/ejs.js +505 -0
- data/vendor/assets/javascripts/glMatrix.js +1772 -0
- data/vendor/assets/javascripts/jasmine.js +2476 -0
- data/vendor/assets/stylesheets/jasmine.css +166 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/alias.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class_deprecated.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class_method.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class_property.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/constant.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/constructor.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/deprecated.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/description.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/information.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/instance_method.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/instance_property.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/method.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/method_deprecated.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/mixin.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/namespace.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/property.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/related_to.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/search-background.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/section-background.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/section.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/selected-section-background.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/subclass.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/superclass.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/utility.png +0 -0
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/application.js +478 -0
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/prototype.js +4874 -0
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/tabs.js +506 -0
- data/vendor/pdoc_template/html/assets/stylesheets/jax.css +30 -0
- data/vendor/pdoc_template/html/assets/stylesheets/pdoc/api.css +681 -0
- data/vendor/pdoc_template/html/assets/stylesheets/pdoc/pygments.css +62 -0
- data/vendor/pdoc_template/html/helpers.rb +35 -0
- data/vendor/pdoc_template/html/index.erb +18 -0
- data/vendor/pdoc_template/html/item_index.js.erb +6 -0
- data/vendor/pdoc_template/html/layout.erb +67 -0
- data/vendor/pdoc_template/html/leaf.erb +22 -0
- data/vendor/pdoc_template/html/node.erb +30 -0
- data/vendor/pdoc_template/html/partials/class_relationships.erb +19 -0
- data/vendor/pdoc_template/html/partials/classes.erb +7 -0
- data/vendor/pdoc_template/html/partials/constructor.erb +5 -0
- data/vendor/pdoc_template/html/partials/description.erb +5 -0
- data/vendor/pdoc_template/html/partials/link_list.erb +1 -0
- data/vendor/pdoc_template/html/partials/method_signatures.erb +14 -0
- data/vendor/pdoc_template/html/partials/methodized_note.erb +9 -0
- data/vendor/pdoc_template/html/partials/mixins.erb +7 -0
- data/vendor/pdoc_template/html/partials/namespaces.erb +7 -0
- data/vendor/pdoc_template/html/partials/related_utilities.erb +5 -0
- data/vendor/pdoc_template/html/partials/relationships.erb +11 -0
- data/vendor/pdoc_template/html/partials/short_description_list.erb +7 -0
- data/vendor/pdoc_template/html/partials/title.erb +24 -0
- data/vendor/pdoc_template/html/section.erb +18 -0
- metadata +635 -332
- data/builtin/app/shaders/lighting/common.ejs +0 -5
- data/builtin/app/shaders/normal_map/material.js +0 -16
- data/builtin/app/shaders/texture/material.js +0 -18
- data/jax.gems +0 -1
- data/lib/jax/application/builtin/configurable.rb +0 -5
- data/lib/jax/application/builtin/configuration.rb +0 -5
- data/lib/jax/application/builtin.rb +0 -12
- data/lib/jax/application/configurable.rb +0 -19
- data/lib/jax/application/configuration.rb +0 -60
- data/lib/jax/application/railties.rb +0 -26
- data/lib/jax/application.rb +0 -149
- data/lib/jax/core_ext/kernel.rb +0 -7
- data/lib/jax/engine/configurable.rb +0 -19
- data/lib/jax/engine/configuration.rb +0 -49
- data/lib/jax/generators/app/app_generator.rb +0 -96
- data/lib/jax/generators/app/templates/Gemfile.tt +0 -3
- data/lib/jax/generators/app/templates/Rakefile +0 -6
- data/lib/jax/generators/app/templates/app/controllers/application_controller.js.tt +0 -5
- data/lib/jax/generators/app/templates/app/helpers/application_helper.js.tt +0 -3
- data/lib/jax/generators/app/templates/config/application.rb.tt +0 -6
- data/lib/jax/generators/app/templates/config/environment.rb.tt +0 -5
- data/lib/jax/generators/app/templates/config/routes.rb.tt +0 -5
- data/lib/jax/generators/app/templates/public/index.html.tt +0 -26
- data/lib/jax/generators/app/templates/public/javascripts/jax.js +0 -9462
- data/lib/jax/generators/app/templates/public/stylesheets/%file_name%.css.tt +0 -11
- data/lib/jax/generators/app/templates/public/webgl_not_supported.html +0 -26
- data/lib/jax/generators/app/templates/script/jax +0 -7
- data/lib/jax/generators/app/templates/spec/javascripts/controllers/application_controller_spec.js +0 -11
- data/lib/jax/generators/app/templates/spec/javascripts/helpers/application_helper_spec.js +0 -12
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine.yml +0 -91
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine_config.rb +0 -23
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine_runner.rb +0 -32
- data/lib/jax/generators/app/templates/spec/javascripts/support/spec_layout.html.erb +0 -104
- data/lib/jax/generators/app.rb +0 -18
- data/lib/jax/generators/commands.rb +0 -220
- data/lib/jax/generators/controller/USAGE +0 -9
- data/lib/jax/generators/controller/controller_generator.rb +0 -66
- data/lib/jax/generators/controller/templates/controller_source.js.tt +0 -16
- data/lib/jax/generators/controller/templates/controller_test.js.tt +0 -11
- data/lib/jax/generators/controller/templates/helper.js.tt +0 -3
- data/lib/jax/generators/controller/templates/helper_test.js.tt +0 -12
- data/lib/jax/generators/interactions.rb +0 -56
- data/lib/jax/generators/light_source/USAGE +0 -14
- data/lib/jax/generators/light_source/light_source_generator.rb +0 -46
- data/lib/jax/generators/material/material_generator.rb +0 -80
- data/lib/jax/generators/material/templates/append.yml.tt +0 -7
- data/lib/jax/generators/model/USAGE +0 -5
- data/lib/jax/generators/model/model_generator.rb +0 -40
- data/lib/jax/generators/model/templates/model.js.tt +0 -11
- data/lib/jax/generators/model/templates/test.js.tt +0 -11
- data/lib/jax/generators/packager/package_generator.rb +0 -32
- data/lib/jax/generators/plugin/USAGE +0 -4
- data/lib/jax/generators/plugin/all.rb +0 -113
- data/lib/jax/generators/plugin/credentials.rb +0 -108
- data/lib/jax/generators/plugin/plugin_generator.rb +0 -72
- data/lib/jax/generators/plugin/plugin_manager.rb +0 -254
- data/lib/jax/generators/plugin/templates/new_plugin/config/routes.rb +0 -3
- data/lib/jax/generators/plugin/templates/new_plugin/spec/.empty_directory +0 -0
- data/lib/jax/generators/script_jax_loader.rb +0 -49
- data/lib/jax/generators/shader/USAGE +0 -4
- data/lib/jax/generators/shader/shader_generator.rb +0 -70
- data/lib/jax/monkeypatch/jasmine/config.rb +0 -45
- data/lib/jax/monkeypatch/jasmine/server.rb +0 -50
- data/lib/jax/monkeypatch/jasmine.rb +0 -3
- data/lib/jax/packager/sprockets_template.rb +0 -77
- data/lib/jax/packager.rb +0 -59
- data/lib/jax/plugin/manifest.rb +0 -71
- data/lib/jax/plugin.rb +0 -49
- data/lib/jax/resource_compiler.rb +0 -60
- data/lib/jax/routes.rb +0 -62
- data/lib/jax/tasks/rake.rb +0 -38
- data/spec/benchmark.htm +0 -93
- data/spec/generators/app_generator_test.rb +0 -42
- data/spec/generators/controller_generator_test.rb +0 -47
- data/spec/generators/light_generator_test.rb +0 -37
- data/spec/generators/material_generator_test.rb +0 -22
- data/spec/generators/model_generator_test.rb +0 -26
- data/spec/generators/plugin_generator_test.rb +0 -114
- data/spec/generators/plugin_manager/push_test.rb +0 -59
- data/spec/generators/plugin_manager_test.rb +0 -192
- data/spec/generators/shader_generator_test.rb +0 -38
- data/spec/javascripts/support/jasmine.yml +0 -85
- data/spec/javascripts/support/jasmine_runner.rb +0 -32
- data/spec/lib/jax/application_test.rb +0 -18
- data/spec/lib/jax/generators/plugin/credentials_test.rb +0 -72
- data/spec/lib/jax/packager_test.rb +0 -87
- data/spec/lib/jax/plugin_test.rb +0 -27
- data/spec/lib/jax/reloading_test.rb +0 -23
- data/spec/lib/jax/routes_test.rb +0 -28
- data/spec/lib/jax/shader_test.rb +0 -29
- data/spec/lib/jax/tasks/jax_rake_test.rb +0 -85
- data/spec/support/bases/generator_test_case.rb +0 -108
- data/spec/support/bases/isolated_test_case.rb +0 -148
- data/spec/support/file_exist_matcher.rb +0 -23
- data/spec/support/spec_shell.rb +0 -110
- data/spec/test_app.rb +0 -3
@@ -1,192 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
# require 'test_app'
|
3
|
-
|
4
|
-
class Jax::Generators::Plugin::PluginManagerTest < Jax::Generators::TestCase
|
5
|
-
test "uninstall plugin with install.rb and uninstall.rb calls uninstall.rb but not install.rb" do
|
6
|
-
$install_loaded = $uninstall_loaded = 0
|
7
|
-
stub_file "vendor/plugins/clouds/install.rb", "$install_loaded = 1"
|
8
|
-
stub_file "vendor/plugins/clouds/uninstall.rb", "$uninstall_loaded = 1"
|
9
|
-
|
10
|
-
generate "uninstall", "clouds"
|
11
|
-
assert_equal 0, $install_loaded
|
12
|
-
assert_equal 1, $uninstall_loaded
|
13
|
-
end
|
14
|
-
|
15
|
-
test "uninstall missing plugin" do
|
16
|
-
result = generate "uninstall", "clouds"
|
17
|
-
|
18
|
-
assert_match /aborted/, result
|
19
|
-
assert_match /Plugin 'clouds' does not seem to be installed./, result
|
20
|
-
end
|
21
|
-
|
22
|
-
test "uninstall previously installed with inexact multiple matches, selecting all" do
|
23
|
-
generate 'install', 'clouds'
|
24
|
-
generate 'install', 'vertex-height-map'
|
25
|
-
generate 'install', 'vertex-blob'
|
26
|
-
|
27
|
-
stdin.returns "0\n"
|
28
|
-
generate "uninstall", "vertex"
|
29
|
-
|
30
|
-
assert_no_directory "vendor/plugins/vertex-height-map"
|
31
|
-
assert_no_directory "vendor/plugins/vertex-blob"
|
32
|
-
assert_directory "vendor/plugins/clouds" # because it doesn't match 'vertex*'
|
33
|
-
end
|
34
|
-
|
35
|
-
test "uninstall previously installed with inexact multiple matches, selecting one" do
|
36
|
-
generate 'install', 'clouds'
|
37
|
-
generate 'install', 'vertex-height-map'
|
38
|
-
generate 'install', 'vertex-blob'
|
39
|
-
|
40
|
-
stdin.returns "2\n"
|
41
|
-
generate "uninstall", "vertex"
|
42
|
-
|
43
|
-
assert_no_directory "vendor/plugins/vertex-height-map"
|
44
|
-
assert_directory "vendor/plugins/vertex-blob"
|
45
|
-
assert_directory "vendor/plugins/clouds"
|
46
|
-
end
|
47
|
-
|
48
|
-
test "uninstall previously installed with inexact single match aborted" do
|
49
|
-
generate 'install', 'clouds'
|
50
|
-
generate 'install', 'vertex-height-map'
|
51
|
-
generate 'install', 'vertex-blob'
|
52
|
-
|
53
|
-
stdin.returns "n\n"
|
54
|
-
generate "uninstall", "cloud"
|
55
|
-
|
56
|
-
assert_directory "vendor/plugins/clouds"
|
57
|
-
end
|
58
|
-
|
59
|
-
test "uninstall previously installed with inexact single match confirmed" do
|
60
|
-
generate 'install', 'clouds'
|
61
|
-
generate 'install', 'vertex-height-map'
|
62
|
-
generate 'install', 'vertex-blob'
|
63
|
-
|
64
|
-
stdin.returns "y\n"
|
65
|
-
generate "uninstall", "cloud"
|
66
|
-
|
67
|
-
assert_no_directory "vendor/plugins/clouds"
|
68
|
-
end
|
69
|
-
|
70
|
-
test "uninstall exact match" do
|
71
|
-
generate 'install', 'clouds'
|
72
|
-
generate 'install', 'vertex-height-map'
|
73
|
-
generate 'install', 'vertex-blob'
|
74
|
-
generate "uninstall", "clouds"
|
75
|
-
|
76
|
-
assert_directory "vendor/plugins/vertex-height-map"
|
77
|
-
assert_directory "vendor/plugins/vertex-blob"
|
78
|
-
assert_no_directory "vendor/plugins/clouds"
|
79
|
-
end
|
80
|
-
|
81
|
-
test "install with install.rb and uninstall.rb" do
|
82
|
-
$install_loaded = $uninstall_loaded = 0
|
83
|
-
generate "install", "clouds"
|
84
|
-
|
85
|
-
assert_equal 1, $install_loaded
|
86
|
-
assert_equal 0, $uninstall_loaded
|
87
|
-
end
|
88
|
-
|
89
|
-
test 'install with default multiple matches' do
|
90
|
-
stdin.returns "2"
|
91
|
-
generate "install", "vert"
|
92
|
-
|
93
|
-
assert_directory "vendor/plugins/vertex-blob"
|
94
|
-
assert_no_directory "vendor/plugins/vertex-height-map"
|
95
|
-
end
|
96
|
-
|
97
|
-
test 'install with default single inexact match confirmed' do
|
98
|
-
stdin.returns "y\n"
|
99
|
-
generate "install", "cloud"
|
100
|
-
|
101
|
-
assert_directory "vendor/plugins/clouds"
|
102
|
-
end
|
103
|
-
|
104
|
-
test 'install with default single inexact match aborted' do
|
105
|
-
stdin.returns "n\n"
|
106
|
-
generate 'install', 'cloud'
|
107
|
-
|
108
|
-
assert_no_directory "vendor/plugins/clouds"
|
109
|
-
end
|
110
|
-
|
111
|
-
test "install with default exact match" do
|
112
|
-
result = generate 'install', 'clouds'
|
113
|
-
|
114
|
-
assert_directory 'vendor/plugins/clouds'
|
115
|
-
assert_match /1\.0\.2/, result
|
116
|
-
end
|
117
|
-
|
118
|
-
test "install with old version exact match" do
|
119
|
-
result = generate 'install', 'clouds', '--version=1.0.0'
|
120
|
-
|
121
|
-
assert_directory "vendor/plugins/clouds"
|
122
|
-
assert_match /1\.0\.0/, result
|
123
|
-
end
|
124
|
-
|
125
|
-
test "install with old version shorthand exact match" do
|
126
|
-
result = generate 'install', 'clouds', '-v=1.0.0'
|
127
|
-
|
128
|
-
assert_directory "vendor/plugins/clouds"
|
129
|
-
assert_match /1\.0\.0/, result
|
130
|
-
end
|
131
|
-
|
132
|
-
test 'list local only with plugins installed with a filter' do
|
133
|
-
generate 'install', 'vertex-blob', 'vertex-height-map'
|
134
|
-
result = generate 'list', 'vertex-b', '--local'
|
135
|
-
|
136
|
-
assert_match /vertex-blob/, result
|
137
|
-
assert_match /#{Regexp::escape 'Adds a shader that deforms meshes, producing "blobs".'}/, result
|
138
|
-
assert_no_match /vertex-height-map/, result
|
139
|
-
assert_no_match /#{Regexp::escape 'Adds a height map generated dynamically in the vertex sha'}/, result
|
140
|
-
end
|
141
|
-
|
142
|
-
test 'list local only with plugins installed' do
|
143
|
-
generate 'install', 'vertex-blob', 'vertex-height-map'
|
144
|
-
result = generate 'list', '--local'
|
145
|
-
|
146
|
-
assert_match /vertex-blob/, result
|
147
|
-
assert_match /#{Regexp::escape 'Adds a shader that deforms meshes, producing "blobs".'}/, result
|
148
|
-
assert_match /vertex-height-map/, result
|
149
|
-
assert_match /#{Regexp::escape 'Adds a height map generated dynamically in the vertex sha'}/, result
|
150
|
-
assert_no_match /clouds/, result
|
151
|
-
assert_no_match /#{Regexp::escape 'Adds a shader for dynamic cloud generation.'}/, result
|
152
|
-
end
|
153
|
-
|
154
|
-
test "list local only with no plugins installed" do
|
155
|
-
result = generate "list", "--local"
|
156
|
-
|
157
|
-
assert_match /There do not seem to be any plugins installed for this application./, result
|
158
|
-
end
|
159
|
-
|
160
|
-
test "list summary" do
|
161
|
-
result = generate 'list'
|
162
|
-
|
163
|
-
assert_match /Adds a height map generated dynamically in the vertex sha\.\.\./, result
|
164
|
-
end
|
165
|
-
|
166
|
-
test 'list detail' do
|
167
|
-
result = generate 'list', '--detailed'
|
168
|
-
|
169
|
-
assert_match /Adds a height map generated dynamically in the vertex shader using Perlin noise\./, result
|
170
|
-
end
|
171
|
-
|
172
|
-
test 'list (all)' do
|
173
|
-
result = generate 'list'
|
174
|
-
|
175
|
-
assert_match /vertex-height-map/, result
|
176
|
-
assert_match /clouds/, result
|
177
|
-
end
|
178
|
-
|
179
|
-
test 'list vertex-height-map' do
|
180
|
-
result = generate 'list', 'vertex-height-map'
|
181
|
-
|
182
|
-
assert_match /vertex-height-map/, result
|
183
|
-
assert_no_match /clouds/, result
|
184
|
-
end
|
185
|
-
|
186
|
-
test 'list clouds' do
|
187
|
-
result = generate 'list', 'clouds'
|
188
|
-
|
189
|
-
assert_no_match /vertex-height-map/, result
|
190
|
-
assert_match /clouds/, result
|
191
|
-
end
|
192
|
-
end
|
@@ -1,38 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
# require 'test_app'
|
3
|
-
|
4
|
-
class Jax::Generators::Shader::ShaderGeneratorTest < Jax::Generators::TestCase
|
5
|
-
include TestHelpers::Paths
|
6
|
-
include TestHelpers::Generation
|
7
|
-
|
8
|
-
EXPECTED_FILES = %w(
|
9
|
-
app/shaders/clouds/common.ejs
|
10
|
-
app/shaders/clouds/fragment.ejs
|
11
|
-
app/shaders/clouds/manifest.yml
|
12
|
-
app/shaders/clouds/material.js
|
13
|
-
app/shaders/clouds/vertex.ejs
|
14
|
-
spec/javascripts/shaders/clouds_spec.js
|
15
|
-
)
|
16
|
-
|
17
|
-
test "generator" do
|
18
|
-
build_app
|
19
|
-
boot_app
|
20
|
-
self.class.destination app_path
|
21
|
-
generate 'clouds'
|
22
|
-
|
23
|
-
EXPECTED_FILES.each do |fi|
|
24
|
-
assert_file fi
|
25
|
-
end
|
26
|
-
end
|
27
|
-
|
28
|
-
test "in plugin" do
|
29
|
-
build_app
|
30
|
-
plugin_generator 'clouds'
|
31
|
-
boot_app
|
32
|
-
|
33
|
-
generate "clouds"
|
34
|
-
EXPECTED_FILES.each do |fi|
|
35
|
-
assert_file File.join("vendor/plugins/clouds", fi)
|
36
|
-
end
|
37
|
-
end
|
38
|
-
end
|
@@ -1,85 +0,0 @@
|
|
1
|
-
# src_files
|
2
|
-
#
|
3
|
-
# Return an array of filepaths relative to src_dir to include before jasmine specs.
|
4
|
-
# Default: []
|
5
|
-
#
|
6
|
-
# EXAMPLE:
|
7
|
-
#
|
8
|
-
# src_files:
|
9
|
-
# - lib/source1.js
|
10
|
-
# - lib/source2.js
|
11
|
-
# - dist/**/*.js
|
12
|
-
#
|
13
|
-
src_files:
|
14
|
-
- dist/jax.js
|
15
|
-
- tmp/shaders.js
|
16
|
-
|
17
|
-
# stylesheets
|
18
|
-
#
|
19
|
-
# Return an array of stylesheet filepaths relative to src_dir to include before jasmine specs.
|
20
|
-
# Default: []
|
21
|
-
#
|
22
|
-
# EXAMPLE:
|
23
|
-
#
|
24
|
-
# stylesheets:
|
25
|
-
# - css/style.css
|
26
|
-
# - stylesheets/*.css
|
27
|
-
#
|
28
|
-
stylesheets:
|
29
|
-
|
30
|
-
# helpers
|
31
|
-
#
|
32
|
-
# Return an array of filepaths relative to spec_dir to include before jasmine specs.
|
33
|
-
# Default: ["helpers/**/*.js"]
|
34
|
-
#
|
35
|
-
# EXAMPLE:
|
36
|
-
#
|
37
|
-
# helpers:
|
38
|
-
# - helpers/**/*.js
|
39
|
-
#
|
40
|
-
helpers:
|
41
|
-
|
42
|
-
# spec_files
|
43
|
-
#
|
44
|
-
# Return an array of filepaths relative to spec_dir to include.
|
45
|
-
# Default: ["**/*[sS]pec.js"]
|
46
|
-
#
|
47
|
-
# EXAMPLE:
|
48
|
-
#
|
49
|
-
# spec_files:
|
50
|
-
# - **/*[sS]pec.js
|
51
|
-
#
|
52
|
-
spec_files:
|
53
|
-
|
54
|
-
# src_dir
|
55
|
-
#
|
56
|
-
# Source directory path. Your src_files must be returned relative to this path. Will use root if left blank.
|
57
|
-
# Default: project root
|
58
|
-
#
|
59
|
-
# EXAMPLE:
|
60
|
-
#
|
61
|
-
# src_dir: public
|
62
|
-
#
|
63
|
-
src_dir:
|
64
|
-
|
65
|
-
# spec_dir
|
66
|
-
#
|
67
|
-
# Spec directory path. Your spec_files must be returned relative to this path.
|
68
|
-
# Default: spec/javascripts
|
69
|
-
#
|
70
|
-
# EXAMPLE:
|
71
|
-
#
|
72
|
-
# spec_dir: spec/javascripts
|
73
|
-
#
|
74
|
-
spec_dir:
|
75
|
-
|
76
|
-
# root_dir
|
77
|
-
#
|
78
|
-
# Root directory path. Files in this directory will be mounted in the web server's root ("/") path.
|
79
|
-
# Default: project directory
|
80
|
-
#
|
81
|
-
# EXAMPLE:
|
82
|
-
#
|
83
|
-
# root_dir: public
|
84
|
-
#
|
85
|
-
root_dir: public
|
@@ -1,32 +0,0 @@
|
|
1
|
-
$:.unshift(ENV['JASMINE_GEM_PATH']) if ENV['JASMINE_GEM_PATH'] # for gem testing purposes
|
2
|
-
|
3
|
-
require 'rubygems'
|
4
|
-
require 'jasmine'
|
5
|
-
jasmine_config_overrides = File.expand_path(File.join(File.dirname(__FILE__), 'jasmine_config.rb'))
|
6
|
-
require jasmine_config_overrides if File.exist?(jasmine_config_overrides)
|
7
|
-
if Jasmine::rspec2?
|
8
|
-
require 'rspec'
|
9
|
-
else
|
10
|
-
require 'spec'
|
11
|
-
end
|
12
|
-
|
13
|
-
jasmine_config = Jasmine::Config.new
|
14
|
-
spec_builder = Jasmine::SpecBuilder.new(jasmine_config)
|
15
|
-
|
16
|
-
should_stop = false
|
17
|
-
|
18
|
-
if Jasmine::rspec2?
|
19
|
-
RSpec.configuration.after(:suite) do
|
20
|
-
spec_builder.stop if should_stop
|
21
|
-
end
|
22
|
-
else
|
23
|
-
Spec::Runner.configure do |config|
|
24
|
-
config.after(:suite) do
|
25
|
-
spec_builder.stop if should_stop
|
26
|
-
end
|
27
|
-
end
|
28
|
-
end
|
29
|
-
|
30
|
-
spec_builder.start
|
31
|
-
should_stop = true
|
32
|
-
spec_builder.declare_suites
|
@@ -1,18 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
class Jax::ApplicationTest < IsolatedTestCase
|
4
|
-
def setup
|
5
|
-
build_app
|
6
|
-
app_file "app/shaders/clouds/fragment.ejs", "void main(void) { }"
|
7
|
-
boot_app
|
8
|
-
end
|
9
|
-
|
10
|
-
test "shaders" do
|
11
|
-
assert_not_nil Jax.application.shaders.find("clouds")
|
12
|
-
assert_equal abs("app/shaders/clouds"), Jax.application.shaders.find("clouds").path
|
13
|
-
end
|
14
|
-
|
15
|
-
test "paths" do
|
16
|
-
assert_contains Jax.root.to_s, Jax.application.javascript_source_roots
|
17
|
-
end
|
18
|
-
end
|
@@ -1,72 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
class Jax::Generators::Plugin::CredentialsTest < IsolatedTestCase
|
4
|
-
def shell
|
5
|
-
@shell ||= SpecShell.new
|
6
|
-
end
|
7
|
-
|
8
|
-
def subject
|
9
|
-
@subject ||= Jax::Generators::Plugin::Credentials.new(
|
10
|
-
:home => FIXTURES_PATH,
|
11
|
-
:in => shell.stdin,
|
12
|
-
:out => shell.stdout
|
13
|
-
)
|
14
|
-
end
|
15
|
-
|
16
|
-
def setup
|
17
|
-
build_app
|
18
|
-
boot_app
|
19
|
-
FileUtils.rm fixture_path(".jax") if File.exist?(fixture_path(".jax"))
|
20
|
-
end
|
21
|
-
|
22
|
-
test "with new account" do
|
23
|
-
shell.stdin.returns [
|
24
|
-
'missing@gmail.com',
|
25
|
-
'password', 'password'
|
26
|
-
]
|
27
|
-
|
28
|
-
assert_equal "WXTzIXC2ODdbLAyvVL9p", subject.api_key
|
29
|
-
end
|
30
|
-
|
31
|
-
test "with missing config file and valid existing credentials" do
|
32
|
-
shell.stdin.returns [
|
33
|
-
'sinisterchipmunk@gmail.com',
|
34
|
-
'password'
|
35
|
-
]
|
36
|
-
|
37
|
-
assert_equal "WXTzIXC2ODdbLAyvVL9p", subject.api_key
|
38
|
-
end
|
39
|
-
|
40
|
-
test "with missing config file and invalid credentials for an existing account" do
|
41
|
-
shell.stdin.returns [
|
42
|
-
'missing@gmail.com',
|
43
|
-
'invalid'
|
44
|
-
]
|
45
|
-
|
46
|
-
assert_raises(RuntimeError) { subject.api_key }
|
47
|
-
end
|
48
|
-
|
49
|
-
test "with missing api key" do
|
50
|
-
shell.stdin.returns [
|
51
|
-
'missing@gmail.com',
|
52
|
-
'password', 'password'
|
53
|
-
]
|
54
|
-
subject.api_key
|
55
|
-
|
56
|
-
assert_match /email/i, shell.stdout.string
|
57
|
-
end
|
58
|
-
|
59
|
-
test "with api key" do
|
60
|
-
stub_fixture(".jax") { |f| f.print 'api_key: "1234"' }
|
61
|
-
|
62
|
-
assert_equal "1234", subject.api_key
|
63
|
-
end
|
64
|
-
|
65
|
-
test "default home" do
|
66
|
-
assert_equal File.expand_path("~"), Jax::Generators::Plugin::Credentials.new.home
|
67
|
-
end
|
68
|
-
|
69
|
-
test "override home" do
|
70
|
-
assert_equal File.expand_path("."), Jax::Generators::Plugin::Credentials.new(:home => ".").home
|
71
|
-
end
|
72
|
-
end
|
@@ -1,87 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
class Jax::Generators::Packager::PackageGeneratorTest < Jax::Generators::TestCase
|
4
|
-
include TestHelpers::Paths
|
5
|
-
include TestHelpers::Generation
|
6
|
-
|
7
|
-
setup do
|
8
|
-
build_app
|
9
|
-
app_file "public/asset.txt", 'content'
|
10
|
-
app_file 'app/helpers/my_helper.js', 'var MyHelper = "ONE";'
|
11
|
-
app_file "app/models/my_model.js", "//= require <support.js>\nvar MyModel = 'TWO';"
|
12
|
-
app_file "app/resources/my_models/default.yml", "three: 3"
|
13
|
-
app_file "app/resources/my_models/first.yml", "four: 4"
|
14
|
-
app_file "app/controllers/my_controller.js", "//= require \"application_controller.js\"\nvar MyController = Jax.Controller.create('my', ApplicationController, {});"
|
15
|
-
app_file "lib/support.js", "var SUPPORT = 1.0;"
|
16
|
-
|
17
|
-
plugin "cloud" do |p|
|
18
|
-
p.write "app/shaders/cloud/vertex.ejs", "void main() { }"
|
19
|
-
p.write "public/plugin-asset.txt", 'content'
|
20
|
-
|
21
|
-
p.write 'app/helpers/plugin_helper.js', 'var PluginHelper = "ONE";'
|
22
|
-
p.write "app/models/plugin_model.js", "//= require <plugin/support.js>\nvar PluginModel = 'TWO';"
|
23
|
-
p.write "app/resources/plugin_models/default.yml", "five: 5"
|
24
|
-
p.write "app/resources/plugin_models/second.yml", "six: 6"
|
25
|
-
p.write "app/controllers/plugin_controller.js", "//= require <application_controller.js>\nvar PluginController = Jax.Controller.create('plugin', ApplicationController, {});"
|
26
|
-
p.write "lib/plugin/support.js", "var PLUGIN_SUPPORT = 1.0;"
|
27
|
-
end
|
28
|
-
|
29
|
-
boot_app
|
30
|
-
self.class.destination Jax.root.to_s
|
31
|
-
@result = run_generator([])
|
32
|
-
end
|
33
|
-
|
34
|
-
test "lib" do
|
35
|
-
assert_file "pkg/javascripts/app_template.js" do |content|
|
36
|
-
assert_match /var SUPPORT = 1.0;/, content
|
37
|
-
assert_match /var PLUGIN_SUPPORT = 1.0;/, content
|
38
|
-
end
|
39
|
-
end
|
40
|
-
|
41
|
-
test "controllers" do
|
42
|
-
assert_file "pkg/javascripts/app_template.js" do |content|
|
43
|
-
# app and plugin controllers should both exist
|
44
|
-
assert_match /var MyController = Jax.Controller.create\('my', ApplicationController/, content
|
45
|
-
assert_match /var PluginController = Jax.Controller.create\('plugin', ApplicationController/, content
|
46
|
-
|
47
|
-
# application controller should precede both
|
48
|
-
assert_match /ApplicationController\s*=.*?MyController\s*=/m, content
|
49
|
-
assert_match /ApplicationController\s*=.*?PluginController\s*=/m, content
|
50
|
-
end
|
51
|
-
end
|
52
|
-
|
53
|
-
test "assets" do
|
54
|
-
assert_file "pkg/asset.txt"
|
55
|
-
assert_file "pkg/plugin-asset.txt"
|
56
|
-
end
|
57
|
-
|
58
|
-
test "models" do
|
59
|
-
assert_file "pkg/javascripts/app_template.js" do |content|
|
60
|
-
assert_match /var MyModel = 'TWO';/, content
|
61
|
-
assert_match /var PluginModel = 'TWO';/, content
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
test "resources" do
|
66
|
-
assert_file "pkg/javascripts/app_template.js" do |content|
|
67
|
-
content =~ /MyModel.addResources\((.*)?\)/
|
68
|
-
assert_not_nil $1, "MyModel has no resources"
|
69
|
-
hash = ActiveSupport::JSON.decode($1)
|
70
|
-
assert_equal 3, hash['default']['three']
|
71
|
-
assert_equal 4, hash['first']['four']
|
72
|
-
|
73
|
-
content =~ /PluginModel.addResources\((.*)?\)/
|
74
|
-
assert_not_nil $1, "PluginModel has no resources"
|
75
|
-
hash = ActiveSupport::JSON.decode($1)
|
76
|
-
assert_equal 5, hash['default']['five']
|
77
|
-
assert_equal 6, hash['second']['six']
|
78
|
-
end
|
79
|
-
end
|
80
|
-
|
81
|
-
test "helpers" do
|
82
|
-
assert_file "pkg/javascripts/app_template.js" do |content|
|
83
|
-
assert_match /var MyHelper = "ONE";/, content
|
84
|
-
assert_match /var PluginHelper = "ONE";/, content
|
85
|
-
end
|
86
|
-
end
|
87
|
-
end
|
data/spec/lib/jax/plugin_test.rb
DELETED
@@ -1,27 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
# see also ./packager_test.rb for plugin stuff related to app packaging
|
4
|
-
|
5
|
-
class Jax::PluginTest < IsolatedTestCase
|
6
|
-
def setup
|
7
|
-
build_app
|
8
|
-
plugin "cloud" do |p|
|
9
|
-
p.write "app/shaders/cloud/vertex.ejs", "void main() { }"
|
10
|
-
end
|
11
|
-
|
12
|
-
boot_app
|
13
|
-
end
|
14
|
-
|
15
|
-
test "detecting presence of plugin" do
|
16
|
-
assert_not_empty Jax.application.plugins
|
17
|
-
end
|
18
|
-
|
19
|
-
test "plugin shaders" do
|
20
|
-
assert_not_nil Jax.application.shaders.find("cloud")
|
21
|
-
assert_equal abs("vendor/plugins/cloud/app/shaders/cloud"), Jax.application.shaders.find("cloud").path
|
22
|
-
end
|
23
|
-
|
24
|
-
test "plugin paths" do
|
25
|
-
assert_contains abs("vendor/plugins/cloud"), Jax.application.javascript_source_roots
|
26
|
-
end
|
27
|
-
end
|
@@ -1,23 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
class Jax::ReloadingTest < IsolatedTestCase
|
4
|
-
def setup
|
5
|
-
build_app
|
6
|
-
app_file "app/shaders/clouds/fragment.ejs", "void main(void) { }"
|
7
|
-
boot_app
|
8
|
-
end
|
9
|
-
|
10
|
-
test "shaders" do
|
11
|
-
assert_match /#{Regexp::escape("void main(void) { }")}/, Jax.application.shaders.find("clouds").fragment
|
12
|
-
|
13
|
-
app_file "app/shaders/clouds/fragment.ejs", "void main(void) { gl_FragColor = vec4(1,1,1,1); }"
|
14
|
-
assert_match /#{Regexp::escape("void main(void) { gl_FragColor = vec4(1,1,1,1); }")}/,
|
15
|
-
Jax.application.shaders.find("clouds").fragment
|
16
|
-
end
|
17
|
-
|
18
|
-
test "resources" do
|
19
|
-
assert_no_match(/#{Regexp::escape "Door"}/, Jax.application.resources.to_s)
|
20
|
-
app_file "app/resources/doors/default.yml", "one: 1"
|
21
|
-
assert_match(/#{Regexp::escape "Door"}/, Jax.application.resources.to_s)
|
22
|
-
end
|
23
|
-
end
|
data/spec/lib/jax/routes_test.rb
DELETED
@@ -1,28 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
require 'stringio'
|
3
|
-
|
4
|
-
class Jax::RoutesTest < ActiveSupport::TestCase
|
5
|
-
def subject
|
6
|
-
@subject ||= Jax::Routes.new
|
7
|
-
end
|
8
|
-
|
9
|
-
setup { @out = ""; @io = StringIO.new(@out) }
|
10
|
-
|
11
|
-
test "should map root" do
|
12
|
-
subject.root "welcome"
|
13
|
-
subject.compile(@io)
|
14
|
-
assert_equal 'Jax.routes.root(WelcomeController, "index");', @out.strip
|
15
|
-
end
|
16
|
-
|
17
|
-
test "should map" do
|
18
|
-
subject.map "path/to", "welcome"
|
19
|
-
subject.compile(@io)
|
20
|
-
assert_equal 'Jax.routes.map("path/to", WelcomeController, "index");', @out.strip
|
21
|
-
end
|
22
|
-
|
23
|
-
test "should map with action name" do
|
24
|
-
subject.map "path/to", "welcome", "another"
|
25
|
-
subject.compile(@io)
|
26
|
-
assert_equal 'Jax.routes.map("path/to", WelcomeController, "another");', @out.strip
|
27
|
-
end
|
28
|
-
end
|
data/spec/lib/jax/shader_test.rb
DELETED
@@ -1,29 +0,0 @@
|
|
1
|
-
require 'test_helper'
|
2
|
-
|
3
|
-
class Jax::ShaderTest < ActiveSupport::TestCase
|
4
|
-
def subject
|
5
|
-
@subject ||= Jax::Shader.new("path/to/shader")
|
6
|
-
end
|
7
|
-
|
8
|
-
test "subject properties" do
|
9
|
-
assert_equal "shader", subject.name
|
10
|
-
assert_equal "path/to/shader", subject.path
|
11
|
-
end
|
12
|
-
|
13
|
-
test "with an export" do
|
14
|
-
subject.fragment = "void main(void)\n{\n vec4 ambient;\n export(vec4, ambient, ambient);\n}"
|
15
|
-
|
16
|
-
# This has to be done in JS because we can't possibly avoid variable redefinitions at this stage
|
17
|
-
# it's this or have broken shader chains whenever two shaders happen to export the same variable
|
18
|
-
assert_no_match(/vec4 _shader_ambient;/, subject.to_s)
|
19
|
-
assert_match /exports: \{['"]ambient['"]:\s*['"]vec4['"]\},/, subject.to_s
|
20
|
-
end
|
21
|
-
|
22
|
-
test "with an import" do
|
23
|
-
subject.fragment = "void main(void)\n{\n vec4 a = import(ambient);\n}"
|
24
|
-
|
25
|
-
# This has to be done in JavaScript because we can't possibly know the exports of other shaders at this stage...
|
26
|
-
# it's this or have broken shader chains whenever they're not used in an expected order
|
27
|
-
assert_no_match(/_shader_ambient/, subject.to_s)
|
28
|
-
end
|
29
|
-
end
|