• Home

  • Custom Ecommerce
  • Application Development
  • Database Consulting
  • Cloud Hosting
  • Systems Integration
  • Legacy Business Systems
  • Security & Compliance
  • GIS

  • Expertise

  • About Us
  • Our Team
  • Clients
  • Blog
  • Careers

  • VisionPort

  • Contact
  • MediaWiki minor upgrade with patches

    Greg Sabino Mullane

    By Greg Sabino Mullane
    October 2, 2014

    One of the more mundane (but important!) tasks for those running MediaWiki is keeping it updated with the latest version of the software. This is usually a fairly easy process. While the offical upgrade instructions for MediaWiki are good, they are missing some important items. I will lay out in detail what we do to upgrade MediaWiki installations.

    Note that this is for “minor” upgrades to MediaWiki, where minor is defined as not moving more than a couple of actual versions, and not requiring anything other than patching some files. I will cover major upgrades in a future post. For this article, I assume you have full shell access, and not simply FTP, to the server that MediaWiki is running on.

    The first step in upgrading is knowing when to upgrade - in other words, making sure you know about new releases. The best way to do this is to subscribe to the low-volume mediawiki-announce mailing list. The MediaWiki maintainers have a wonderful new policy of sending out “pre-announcement” emails stating the exact time that the new version will be released. Once we see that announcement, or when the version is actually released, we open a support …


    mediawiki

    RSpec’s Anything Argument Matcher Trickery

    Brian Gadoury

    By Brian Gadoury
    September 29, 2014

    If you’re like me, and I know I am, then you’ve used RSpec’s “anything” argument matcher to test that a method is getting called with the expected arguments. If you haven’t, then I strongly recommend you check it out. Here’s a basic example:

    expect(object).to receive(:message).with(:foo, anything)

    That test will pass if object.message() is called with :foo as its first argument, and any non-nil value as its second argument. The “anything” matcher can be used anywhere in the argument list, as well as multiple times. For example:

    expect(object).to receive(:message).with(anything, :bar, anything)

    That test will pass if object.message() is called with a non-nil value for its first argument, :bar for its second argument, and any non-nil value for its third argument.

    I recently made one of those discoveries where the happiness of making the discovery quickly turned into the sneaking suspicion that I was actually the last person on the planet to make this discovery. So, I told a co-worker about my discovery. She hadn’t heard of it before, which meant at worst I was the second to last person on the planet. “There could be others,” I thought. “I must set alight our grail shaped beacon!” …


    ruby rails testing

    Using jQuery Migrate plugin

    Marina Lohova

    By Marina Lohova
    September 26, 2014

    We all know these tricky situations, like introducing a new feature on top of old code, when it seems we’re about to step into a tedious swamp of workarounds and dirty hacks. Fortunately, jQuery Migrate plugin is here to make these situations easier, at least in JavaScript. So for any of you who wondered about a real-life example of using jQuery Migrate plugin I have one!

    My task was to add an editable combomonster, oh sorry, combobox (even though editable comboboxes remind me of UX Frankenstein’s Monster, they are still requested a lot) to a rather old website built on jQuery v1.4.2.

    I downloaded the most recent jQuery UI (at that time it was v1.10.4) and a very neat editable combobox component to go with it. It was expected that it wouldn’t work out of box with the rather outdated jQuery we had. It didn’t work and the page produced the following JavaScript error:

    TypeError: t.cssHooks is undefined
    ...t(" ");f(i,function(e,i){t.cssHooks[i]={set:function(e,n){var a,o,r="";if("trans...

    No problem, I grab the newer compatible jQuery v1.10.2 from the website and yield it into head in that particular page.

    <% content_for  :head do %>
      javascript_include_tag …

    javascript jquery

    Solving pg_xlog out of disk space problem on Postgres

    Greg Sabino Mullane

    By Greg Sabino Mullane
    September 25, 2014


    pg_xlog with a dummy file
    (image by Andrew Malone)

    Running out of disk space in the pg_xlog directory is a fairly common Postgres problem. This important directory holds the WAL (Write Ahead Log) files. (WAL files contain a record of all changes made to the database—​see the link for more details). Because of the near write‑only nature of this directory, it is often put on a separate disk. Fixing the out of space error is fairly easy: I will discuss a few remedies below.

    When the pg_xlog directory fills up and new files cannot be written to it, Postgres will stop running, try to automatically restart, fail to do so, and give up. The pg_xlog directory is so important that Postgres cannot function until there is enough space cleared out to start writing files again. When this problem occurs, the Postgres logs will give you a pretty clear indication of the problem. They will look similar to this:

    PANIC:  could not write to file "pg_xlog/xlogtemp.559": No space left on device
    STATEMENT:  insert into abc(a) select 123 from generate_series(1,12345)
    LOG:  server process (PID 559) was terminated by signal 6: Aborted
    DETAIL:  Failed process was running: insert into abc(a) select …

    postgres

    Some metaprogramming examples from RSpec

    Miguel Alatorre

    By Miguel Alatorre
    September 25, 2014

    I’m quite the curious cat and one thing that has interested me for a while has been how RSpec and its describe and it methods work. In digging through the rspec-core gem source code (v3.1.4), specifically the example_group.rb file, I came across some syntax that I had not been exposed to:

    # https://github.com/rspec/rspec-core/blob/v3.1.3/lib/rspec/core/example_group.rb
    
    module RSpec
      module Core
        class ExampleGroup
          # ...
    
          def self.define_singleton_method(*a, &b)
            (class << self; self; end).__send__(:define_method, *a, &b)
          end
    
          # ...
    
          def self.define_example_method(name, extra_options={})
            define_singleton_method(name) do |*all_args, &block|
    
              # ...
    
            end
          end
    
          # ...
    
          define_example_method :it
    
          # ...
    
        end
      end
    end

    “What’s with all this passing around of blocks? And what’s :define_method doing?” I asked. The documentation for the define_method is straightforward enough, yet I still wondered what was being accomplished in the code above. In pursuit of answers, here’s what I found out.

    Metaprogramming

    Metaprogramming is the writing of code that acts on other code instead of …


    ruby testing

    Spree Authorization Failure for Customized Role

    Matt Galvin

    By Matt Galvin
    September 22, 2014

    Hello again all. Recently I was working on another Spree site running Spree 2.1.1. The client wanted to create some custom roles. For example, the client wanted there to be a Sales Manager role. A Sales Manager could log in and have read and write access to all the orders. However, a sales manager should not have read/write access to products, configuration, promotions, users, etc. This was easily accomplished by following the steps in the Spree documentation. As I will describe, this documentation assumes that the custom role will have access to Orders#index.

    The client wanted to create a second custom role that had create, read, update and delete access to the Training model and nothing more. The training model belongs to a taxon and has a unique event date and taxon id. An example would be a training instance with an event date of September 9th, 2014 that belongs to a taxon with the name “Fire Safety 101” and a description “Teaching fire safety in accordance with OSHA standards. 10 hours and lunch is provided”. So, I planned to create a training personnel role that should be able to log in and only have read/write access to Trainings. However, the Spree documentation did not …


    ruby rails spree

    Piggybak: Recent Updates and Upgrades

    Steph Skardal

    By Steph Skardal
    September 17, 2014

    Piggybak, an open source Ruby on Rails ecommerce gem, implemented as a mountable solution, has continued to be upgraded and maintained over the last several months to keep up to date with Rails security releases and Ruby releases. Here are some quick notes on recent work:

    • Piggybak (version 0.7.5) is now compatible with Rails 4.1.6, which is the most up to date release of Rails. See the Rails release notes for more details on this recent release. The Piggybak Demo is now running on Rails 4.1.6.
    • Piggybak is compatible with Ruby 2.1.2, and the demo is running on Ruby 2.1.2.
    • Recent updates in Piggybak include migration fixes to handle table namespace issues, and updates to remove methods that are no longer present in Rails (that were previously deprecated).
    • Recent updates to the demo include updates to the integration testing suite to allow testing to be compatible with Rails 4.1.6, as well as modifications to how the demo handles exceptions.

    Make sure to check out Piggybak on github repository for more details on these recent updates.


    piggybak ruby rails

    Aliasin’ and Redmine plugins

    Miguel Alatorre

    By Miguel Alatorre
    September 16, 2014

    Recently I was tasked with creating a plugin to customize End Point’s Redmine instance. In working through this I was exposed for the first time to alias_method_chain. What follows is my journey down the rabbit hole as I wrap my head around new (to me) Ruby/Rails magic.

    The Rails core method alias_method_chain encapsulates a common pattern of using alias_method twice: first to rename an original method to a method “without" a feature, and second to rename a new method “with" a feature to the original method. Whaaaa? Let’s start by taking a look at Ruby core methods alias and alias_method before further discussing alias_method_chain.

    alias and alias_method

    At first glance, they achieve the same goal with slightly different syntax:

    class Person
      def hello
        "Hello"
      end
    
      alias say_hello hello
    end
    
    Person.new.hello
    => "Hello"
    Person.new.say_hello
    => "Hello"
    class Person
      def hello
        "Hello"
      end
    
      alias_method :say_hello, :hello
    end
    
    Person.new.hello
    => "Hello"
    Person.new.say_hello
    => "Hello"

    Let’s see what happens when we have a class inherit from Person in each of the cases above.

    class Person
      def …

    extensions ruby rails
    Previous page • Page 92 of 222 • Next page