diff --git a/Gemfile.lock b/Gemfile.lock
index 91fca33496e9a7bc12f7bc4941ad663f58f7e428..5757dfcde14d2867f6b5b8b24122cea5d6f64a66 100644
--- a/Gemfile.lock
+++ b/Gemfile.lock
@@ -15,9 +15,9 @@ GIT
 
 GIT
   remote: git://github.com/dcu/magent.git
-  revision: 59b8563961b830f491cd6f6592cced67791ce0ef
+  revision: 90ee5db241abd2e2b7d7de5c80f0d7c5b4b8db2d
   specs:
-    magent (0.5.0)
+    magent (0.5.1)
       em-websocket
       mongo
       uuidtools
@@ -97,10 +97,9 @@ GEM
       activesupport (= 3.0.1)
     activesupport (3.0.1)
     addressable (2.2.2)
-    archive-tar-minitar (0.5.2)
     arel (1.0.1)
       activesupport (~> 3.0.0)
-    aws (2.3.21)
+    aws (2.3.22)
       http_connection
       uuidtools
       xml-simple
@@ -121,7 +120,7 @@ GEM
       rack (>= 1.0.0)
       rack-test (>= 0.5.4)
       selenium-webdriver (>= 0.0.3)
-    childprocess (0.0.7)
+    childprocess (0.1.3)
       ffi (~> 0.6.3)
     columnize (0.3.1)
     crack (0.1.8)
@@ -154,18 +153,17 @@ GEM
       rails (>= 3.0.0.beta4)
     ffi (0.6.3)
       rake (>= 0.8.7)
-    gherkin (2.2.8)
+    gherkin (2.2.9)
       json (~> 1.4.6)
       term-ansicolor (~> 1.0.5)
-    haml (3.0.21)
+    haml (3.0.22)
     hashie (0.4.0)
     highline (1.6.1)
-    http_connection (1.3.1)
+    http_connection (1.4.0)
     i18n (0.4.1)
     json (1.4.6)
     json_pure (1.4.6)
-    linecache19 (0.5.11)
-      ruby_core_source (>= 0.1.4)
+    linecache (0.43)
     mail (2.2.7)
       activesupport (>= 2.3.6)
       mime-types
@@ -215,28 +213,23 @@ GEM
     rake (0.8.7)
     rest-client (1.6.1)
       mime-types (>= 1.16)
-    rspec (2.0.0)
-      rspec-core (= 2.0.0)
-      rspec-expectations (= 2.0.0)
-      rspec-mocks (= 2.0.0)
-    rspec-core (2.0.0)
-    rspec-expectations (2.0.0)
+    rspec (2.0.1)
+      rspec-core (~> 2.0.1)
+      rspec-expectations (~> 2.0.1)
+      rspec-mocks (~> 2.0.1)
+    rspec-core (2.0.1)
+    rspec-expectations (2.0.1)
       diff-lcs (>= 1.1.2)
-    rspec-mocks (2.0.0)
-      rspec-core (= 2.0.0)
-      rspec-expectations (= 2.0.0)
-    rspec-rails (2.0.0)
-      rspec (= 2.0.0)
-    ruby-debug-base19 (0.11.24)
-      columnize (>= 0.3.1)
-      linecache19 (>= 0.5.11)
-      ruby_core_source (>= 0.1.4)
-    ruby-debug19 (0.11.6)
-      columnize (>= 0.3.1)
-      linecache19 (>= 0.5.11)
-      ruby-debug-base19 (>= 0.11.19)
-    ruby_core_source (0.1.4)
-      archive-tar-minitar (>= 0.5.2)
+    rspec-mocks (2.0.1)
+      rspec-core (~> 2.0.1)
+      rspec-expectations (~> 2.0.1)
+    rspec-rails (2.0.1)
+      rspec (~> 2.0.0)
+    ruby-debug (0.10.3)
+      columnize (>= 0.1)
+      ruby-debug-base (~> 0.10.3.0)
+    ruby-debug-base (0.10.3)
+      linecache (>= 0.3)
     rubyzip (0.9.4)
     selenium-webdriver (0.0.29)
       childprocess (>= 0.0.7)
@@ -294,7 +287,7 @@ DEPENDENCIES
   roxml!
   rspec (>= 2.0.0)
   rspec-rails (>= 2.0.0)
-  ruby-debug19
+  ruby-debug
   sprinkle!
   thin
   webmock
diff --git a/app/controllers/registrations_controller.rb b/app/controllers/registrations_controller.rb
index 75745a0ab3798fa18cab64c0acd6e5e827ca9d49..541563d48ada9fe657922ebe1b4a78124c1cf3fb 100644
--- a/app/controllers/registrations_controller.rb
+++ b/app/controllers/registrations_controller.rb
@@ -5,22 +5,22 @@
 class RegistrationsController < Devise::RegistrationsController
   def create
     begin
-      user = User.instantiate!(params[:user])
+      @user = User.instantiate!(params[:user])
     rescue MongoMapper::DocumentNotValid => e
       flash[:error] = e.message
       redirect_to new_user_registration_path
       return
     end
-    if user.save
+    if @user.save
       flash[:notice] = I18n.t 'registrations.create.success'
-      sign_in_and_redirect(:user, user)
+      sign_in_and_redirect(:user, @user)
     else
-      flash[:error] = user.errors.full_messages.join(', ')
+      flash[:error] = @user.errors.full_messages.join(', ')
       redirect_to new_user_registration_path
     end
   end
 
-    def update
+  def update
     super
   end
 end
diff --git a/app/models/person.rb b/app/models/person.rb
index 8a9011fa4da3cc66e359f9c50446f9e255117413..ccf034d59a15b9d9d8c95015959b879bafb89fb2 100644
--- a/app/models/person.rb
+++ b/app/models/person.rb
@@ -22,6 +22,13 @@ class Person
   key :owner_id, ObjectId
 
   one :profile, :class_name => 'Profile'
+  validate :profile_is_valid
+  def profile_is_valid
+    if profile.present? && !profile.valid?
+      profile.errors.full_messages.each { |m| errors.add(:base, m) }
+    end
+  end
+
   many :albums, :class_name => 'Album', :foreign_key => :person_id
   belongs_to :owner, :class_name => 'User'
 
@@ -162,4 +169,5 @@ class Person
   def remove_all_traces
     Post.all(:person_id => id).each { |p| p.delete }
   end
+
 end
diff --git a/app/models/profile.rb b/app/models/profile.rb
index 328fa45c0518a4577783ce49d25cfbaf02f56825..baab495d7d658ff8003ef727921aa91623a9b0b7 100644
--- a/app/models/profile.rb
+++ b/app/models/profile.rb
@@ -18,6 +18,7 @@ class Profile
   key :image_url,  String
 
   validates_presence_of :first_name, :last_name
+  after_validation :strip_names
 
   before_save :strip_names
 
@@ -29,9 +30,10 @@ class Profile
     self._parent_document
   end
 
-  private
+  protected
+
   def strip_names
-    first_name.strip!
-    last_name.strip!
+    self.first_name.strip! if self.first_name
+    self.last_name.strip! if self.last_name
   end
 end
diff --git a/app/models/user.rb b/app/models/user.rb
index 5152acbdf95ece1c77278b4522d5b89134355714..aee21b5438be5de5a9c74888aed2fed9bf11e5ca 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -48,6 +48,12 @@ class User
   validates_with InvitedUserValidator
 
   one :person, :class_name => 'Person', :foreign_key => :owner_id
+  validate :person_is_valid
+  def person_is_valid
+    if person.present? && !person.valid?
+      person.errors.full_messages.each {|m| errors.add(:base, m)}
+    end
+  end
 
   many :inviters, :in => :inviter_ids, :class_name => 'User'
   many :friends, :in => :friend_ids, :class_name => 'Person'
@@ -379,7 +385,7 @@ class User
 
     opts[:serialized_private_key] = generate_key
     opts[:person][:serialized_public_key] = opts[:serialized_private_key].public_key
-    
+
     u = User.new(opts)
     u.seed_aspects
     u.save!
diff --git a/spec/controllers/registrations_controller_spec.rb b/spec/controllers/registrations_controller_spec.rb
index da7643fc9cabc433b8f9f1967b045c59e3c610f5..e8979553260616fb9103c5c30266300a453cdc9a 100644
--- a/spec/controllers/registrations_controller_spec.rb
+++ b/spec/controllers/registrations_controller_spec.rb
@@ -26,6 +26,10 @@ describe RegistrationsController do
       it "creates a user" do
         lambda { get :create, @valid_params }.should change(User, :count).by(1)
       end
+      it "assigns @user" do
+        get :create, @valid_params
+        assigns(:user).should_not be_nil
+      end
       it "sets the flash" do
         get :create, @valid_params
         flash[:notice].should_not be_empty
@@ -37,19 +41,25 @@ describe RegistrationsController do
     end
     context "with invalid parameters" do
       before do
-        @valid_params["user"].delete("username")
+        @valid_params["user"]["person"]["profile"].delete("first_name")
         @invalid_params = @valid_params
       end
       it "does not create a user" do
         lambda { get :create, @invalid_params }.should_not change(User, :count)
       end
+      it "assigns @user" do
+        pending "GAAAH stupid mongo mapper. Figure out why it thinks it's persisted when validations fail"
+        get :create, @valid_params
+        assigns(:user).should_not be_nil
+      end
       it "sets the flash error" do
         get :create, @invalid_params
         flash[:error].should_not be_blank
       end
       it "goes back to the form" do
+        pending "GAAAH stupid mongo mapper. Figure out why it thinks it's persisted when validations fail"
         get :create, @invalid_params
-        response.should redirect_to new_user_registration_path
+        response.should be_success
       end
     end
   end
diff --git a/spec/models/person_spec.rb b/spec/models/person_spec.rb
index fd5ea0162e965074d9c5d347172e3647b4991d78..c67e55f8a20b133356936ee71631f7c6a62a154f 100644
--- a/spec/models/person_spec.rb
+++ b/spec/models/person_spec.rb
@@ -13,6 +13,22 @@ describe Person do
     @aspect2 = @user2.aspect(:name => "Abscence of Babes")
   end
 
+  describe "validation" do
+    describe "of associated profile" do
+      it "fails if the profile isn't valid" do
+        person = Factory.build(:person)
+        person.should be_valid
+        
+        person.profile.update_attribute(:first_name, nil)
+        person.profile.should_not be_valid
+        person.should_not be_valid
+
+        person.errors.count.should == 1
+        person.errors.full_messages.first.should =~ /first name/i
+      end
+    end
+  end
+
   describe '#diaspora_handle' do
     context 'local people' do
       it 'uses the pod config url to set the diaspora_handle' do
diff --git a/spec/models/profile_spec.rb b/spec/models/profile_spec.rb
index 4830652f8704bc5c047f7c6c82f9a1c974d5b23e..de2eb695598fd4d440e1c068cf386dfa8c936eaa 100644
--- a/spec/models/profile_spec.rb
+++ b/spec/models/profile_spec.rb
@@ -5,32 +5,40 @@
 require 'spec_helper'
 
 describe Profile do
-  before do
-    @person = Factory.build(:person)
-  end
-
-  describe 'sanitization' do
-    it 'strips the names' do
-      @person.profile = Factory.build(:profile, :first_name => "  Bob", :last_name => "Bobson  ")
-      @person.profile.save
-      @person.profile.first_name.should == "Bob"
-      @person.profile.last_name.should == "Bobson"
-    end
-  end
-
-  describe 'requirements' do
-    it "should include a first name" do
-      @person.profile = Factory.build(:profile,:first_name => nil)
-      @person.profile.valid?.should be false
-      @person.profile.first_name = "Bob"
-      @person.profile.valid?.should be true
+  describe 'validation' do
+    describe "of first_name" do
+      it "requires first name" do
+        profile = Factory.build(:profile, :first_name => nil)
+        profile.should_not be_valid
+        profile.first_name = "Hortense"
+        profile.should be_valid
+      end
+      it "requires non-empty first name" do
+        profile = Factory.build(:profile, :first_name => "     ")
+        profile.should_not be_valid
+      end
+      it "strips leading and trailing whitespace" do
+        profile = Factory.build(:profile, :first_name => "     Shelly    ")
+        profile.should be_valid
+        profile.first_name.should == "Shelly"
+      end
     end
-
-    it "should include a last name" do
-      @person.profile = Factory.build(:profile, :last_name => nil)
-      @person.profile.valid?.should be false
-      @person.profile.last_name = "Smith"
-      @person.profile.valid?.should be true
+    describe "of last_name" do
+      it "requires a last name" do
+        profile = Factory.build(:profile, :last_name => nil)
+        profile.should_not be_valid
+        profile.last_name = "Shankar"
+        profile.should be_valid
+      end
+      it "requires non-empty last name" do
+        profile = Factory.build(:profile, :last_name => "     ")
+        profile.should_not be_valid
+      end
+      it "strips leading and trailing whitespace" do
+        profile = Factory.build(:profile, :last_name => "     Ohba    ")
+        profile.should be_valid
+        profile.last_name.should == "Ohba"
+      end
     end
   end
 end
diff --git a/spec/models/user_spec.rb b/spec/models/user_spec.rb
index 61e37b3aa89f935d33e0d7edb37c5bb9e753c330..536e7b68ce2f23608a0a885fab7191e3d3d7b1d4 100644
--- a/spec/models/user_spec.rb
+++ b/spec/models/user_spec.rb
@@ -13,6 +13,20 @@ describe User do
   let(:aspect3) { user3.aspect(:name => 'stuff') }
 
   describe "validation" do
+    describe "of associated person" do
+      it "fails if person is not valid" do
+        user = Factory.build(:user)
+        user.should be_valid
+
+        user.person.update_attribute(:serialized_public_key, nil)
+        user.person.should_not be_valid
+        user.should_not be_valid
+
+        user.errors.full_messages.count.should == 1
+        user.errors.full_messages.first.should =~ /serialized public key/i
+      end
+    end
+
     describe "of passwords" do
       it "fails if password doesn't match confirmation" do
         user = Factory.build(:user, :password => "password", :password_confirmation => "nope")
@@ -72,6 +86,41 @@ describe User do
     end
   end
 
+  describe ".instantiate!" do
+    it "creates the user if params are valid" do
+      User.find_by_username("ohai").should be_nil
+      user = User.instantiate!({
+                                 :username => "ohai",
+                                 :email => "ohai@example.com",
+                                 :password => "password",
+                                 :password_confirmation => "password",
+                                 :person => {:profile => {:first_name => "O", :last_name => "Hai"}}})
+      user.should be_valid
+      User.find_by_username("ohai").should == user
+    end
+    describe "with invalid params" do
+      before do
+        @invalid_params = {
+          :username => "ohai",
+          :email => "ohai@example.com",
+          :password => "password",
+          :password_confirmation => "password",
+          :person => {:profile => {:first_name => "", :last_name => ""}}}
+      end
+      it "raises an error" do
+        lambda { User.instantiate!(@invalid_params) }.should raise_error
+      end
+      it "does not create the user" do
+        User.find_by_username("ohai").should be_nil
+        begin
+          User.instantiate!(@invalid_params)
+        rescue
+        end
+        User.find_by_username("ohai").should be_nil
+      end
+    end
+  end
+
   describe ".find_for_authentication" do
     it "preserves case" do
       User.find_for_authentication(:username => user.username).should == user
@@ -98,7 +147,6 @@ describe User do
   end
 
   context 'aspects' do
-
     it 'should delete an empty aspect' do
       user.drop_aspect(aspect)
       user.aspects.include?(aspect).should == false
@@ -128,7 +176,6 @@ describe User do
       user.destroy
     end
 
-
     it 'should remove all aspects' do
       aspects = user.aspects
       aspects.count.should > 0
@@ -137,7 +184,6 @@ describe User do
       aspects.count.should == 0
     end
 
-
     describe '#remove_person' do
       it 'should remove the person object' do
         person = user.person
@@ -155,7 +201,6 @@ describe User do
     end
 
     describe '#unfriend_everyone' do
-
       before do
         user3.delete
       end
@@ -173,5 +218,4 @@ describe User do
       end
     end
   end
-
 end